在执行 rsync
命令之前,可以添加对 rsync 可执行文件的权限检查。您可以使用 os.Stat()
函数获取文件的信息,并通过判断文件的权限是否具有可执行权限来进行检查。以下是修改后的代码示例:
package main
import (
"fmt"
"os"
"os/exec"
)
func checkFilePermissions(path string) error {
info, err := os.Stat(path)
if err != nil {
return err
}
mode := info.Mode()
if mode&0100 == 0 {
return fmt.Errorf("rsync 不具备可执行权限")
}
return nil
}
func main() {
filePath := "/usr/bin/rsync"
err := checkFilePermissions(filePath)
if err != nil {
fmt.Println(err)
return
}
cmd := exec.Command("rsync", "-avz", "--delete", destHost+":"+dir.Dir, dir.Dir)
var stdout, stderr bytes.Buffer
cmd.Stdout = &stdout
cmd.Stderr = &stderr
stdin, err := cmd.StdinPipe()
if err != nil {
c.lc.Errorf("StdinPipe failed:", stdout.String())
}
go func() {
defer stdin.Close()
password := "ght@2022\n"
stdin.Write([]byte(password))
}()
err = cmd.Start()
if err != nil {
c.lc.Errorf("rsync error output: %s", stderr)
return
}
err = cmd.Wait()
if exitError, ok := err.(*exec.ExitError); ok {
if status, ok := exitError.Sys().(syscall.WaitStatus); ok {
c.lc.Errorf("Exited with status %d\n", status.ExitStatus())
c.lc.Errorf("Stdout:", stdout.String())
c.lc.Errorf("Stderr:", stderr.String())
}
}
}
在上面的代码中,我们添加了一个名为 checkFilePermissions()
的函数来检查 rsync 可执行文件的权限。然后,在 main()
函数中,在执行 rsync 命令之前先调用该函数进行权限检查。
请注意,此示例仅考虑了 rsync 可执行文件的可执行权限,并没有涉及到其他可能需要考虑的安全问题。在实际应用中,请根据您的具体需求进行更详细和完善的安全性检查和处理。
内容由零声教学AI助手提供,问题来源于学员提问