我有以下代码,当通过 Command Prompt
调用时,此加密代码可以正常工作(创建加密文件)当它在 Console Application
时同样不起作用.
var destFilePath = @"D:\test.gpg";
var recipient = "test@test.com";
var sourceFilePath = @"D:\test.txt";
var proc = new Process
{
StartInfo = new ProcessStartInfo
{
FileName = "cmd.exe",
Arguments = string.Format("gpg2 --output {0} --encrypt --recipient {1} {2}",
destFilePath, recipient, sourceFilePath),
UseShellExecute = false,
RedirectStandardError = true,
RedirectStandardInput = true,
RedirectStandardOutput = true,
CreateNoWindow = true,
WorkingDirectory = @"C:\Program Files (x86)\GNU\GnuPG"
}
};
proc.Start();
proc.WaitForExit();
int rc = proc.ExitCode;
proc.Close();
Console.WriteLine(rc.ToString());
Console.ReadKey();
在 ExitCode 中返回错误代码 2
任何想法都会有所帮助!
最佳答案
来自 GPG Error Code 2 :
GPG is asking whether you want to continue on with the encryption using an unsigned key. Since no user can input Y it produces an error.
To fix this put the following switches
--yes
and--always-trust
自从我使用 GPG 以来已经有一段时间了,但参数的顺序通常并不重要,只要它们被命名
这会给你这样的东西
FileName = "gpg2.exe",
Arguments = $"--output {destFilePath} --encrypt --yes --always-trust --recipient {recipient} {sourceFilePath}",
注意:这是 C#6 格式,更容易阅读
关于c# - GnuPG 加密不适用于进程错误代码 2,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37025829/