尝试通过 go 命令行指令来启动 veracrypt,但它得到退出状态 1 或不显示错误并且不创建请求的卷。
func main() {
cmd := exec.Command("veracrypt",
"-c", "/home/user/test/samplevolume.vcrypt",
"--volume-type", "normal",
"--filesystem", "FAT",
"--hash", "SHA256",
"--encryption", "AES",
"--size", "10M",
"--pim", "1234",
"-k", "",
"--random-source", "/home/user/test/README.md")
var out bytes.Buffer
var stderr bytes.Buffer
cmd.Stderr = &stderr
stdin, err := cmd.StdinPipe()
if err != nil {
fmt.Println(fmt.Sprint(err))
}
go func() {
defer stdin.Close()
err = cmd.Run()
// io.WriteString(stdin, "1234")
// io.WriteString(stdin, "y")
// io.WriteString(stdin, "1234")
}()
if err != nil {
fmt.Println(fmt.Sprint(err) + ": " + stderr.String())
return
}
fmt.Println("Result: " + out.String())
// outin, err := cmd.CombinedOutput()
// if err != nil {
// log.Fatal(err)
// }
// fmt.Printf("%s\n", outin)
}
注释部分是我使用的另一种方法,它导致退出状态 1。
之所以要传入“1234”、y、“1234”结尾的3个字符串,是因为我们要交互输入密码。
该代码最终不会创建 veracrypt 文件。
这是我们尝试使用 golang 调用的 veracrypt 的命令行说明。
veracrypt -c ~/test/samplevolume.vcrypt --volume-type normal --filesystem FAT --hash SHA256 --encryption AES --size 10M --pim 1234 -k= --random-source ~/test/README.md
注意:如果重要的话,一切都在 linux 上。
编辑:另外,我是golang的新手,如果我犯了一个明显的错误,对不起。