ZBLOG

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:...

在执行 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助手提供,问题来源于学员提问

本站部分文章来源于网络,版权归原作者所有,如有侵权请联系站长删除。
转载请注明出处:https://golang.0voice.com/?id=18304

分享:
扫描分享到社交APP
上一篇
下一篇
发表列表
游客 游客
此处应有掌声~
评论列表

还没有评论,快来说点什么吧~

联系我们

在线咨询: 点击这里给我发消息

微信号:3007537140

上班时间: 10:30-22:30

关注我们
x

注册

已经有帐号?