我们有一个.NET应用程序,可以使用winzip(winzip32.exe)作为进程自动压缩文件。该过程类似于从命令行使用winzip压缩文件。
我们已经配置了一个调度程序来每天运行这个应用程序,并且它从很长一段时间内成功运行。
几天后我们遇到了问题,并且没有创建zip文件。 但是,我看到winzip实例已创建并正在运行但是没有发生压缩。 在发行当天,机器上没有观察到不均匀的情况。
您能帮助我们解决可能存在的问题,或者在什么情况下,流程无法压缩文件。
参考代码段:
string WinzipPath = ConfigurationManager.AppSettings["WinzipPath"] ;
System.Diagnostics.Process objProc = new System.Diagnostics.Process();
objProc.StartInfo.FileName = WinzipPath;
if(strPassword != "")
{
objProc.StartInfo.Arguments = string.Format("-min -a -en -r -s\"{0}\" {1} {2}", strPassword, strzipFilePath, strFileNames);
}
else
{
objProc.StartInfo.Arguments = string.Format("-min -a -en -r \"{0}\" {1}", strzipFilePath, strFileNames);
}
objProc.StartInfo.RedirectStandardOutput = true;
objProc.StartInfo.UseShellExecute = false;
objProc.StartInfo.CreateNoWindow = true;
objProc.Start();
objProc.WaitForExit();
提前致谢
答案 0 :(得分:0)
我同意您的评论者在应用中使用DotNetZip更好。
即使您不接受这些建议,如果您继续使用wzzip.exe,也可以采取一些简单的方法来改善您的生活。第一:收集并记录标准输出和标准错误。您的代码重定向标准输出,但不记录或显示它。它忽略了标准错误消息。第二:检查流程的退出代码。
根据我的经验,当命令行winzip程序失败时,它向stdout发出一些内容,描述失败。 “找不到文件”或“不一致的选项”或类似的东西。
另外:wzzip.exe的输出非常详细。它在运行时发出进度消息,然后发出退格键以“擦除”最新消息,然后发出另一个进度消息,依此类推。 wzzip.exe输出的80%或更多可以是退格。使用所有这些输出,wzzip.exe可以填充输出缓冲区。如果您未在应用程序中阅读它们,则可能会遇到死锁情况。
因此,您应该阅读stdout和stderr有两个原因:检查结果,还要避免因完整输出缓冲区而导致的死锁。
DotNetZip的测试套件包括成功运行wzzip.exe的代码,以确保winzip与dotnetzip兼容,反之亦然。这基本上就是它的样子(取自TestUtilities.cs):
public void Exec(string program, string args)
{
System.Diagnostics.Process p = new System.Diagnostics.Process
{
StartInfo =
{
FileName = program, // wzzip.exe in your case
CreateNoWindow = true,
Arguments = args, // whatever you like
WindowStyle = System.Diagnostics.ProcessWindowStyle.Hidden,
UseShellExecute = false,
}
};
p.StartInfo.RedirectStandardOutput = true;
p.StartInfo.RedirectStandardError = true;
// Must read at least one of the stderr or stdout asynchronously,
// to avoid deadlock. I choose to read stderr asynchronously.
var sb = new StringBuilder();
p.ErrorDataReceived += new DataReceivedEventHandler((o, e) => {
if (!String.IsNullOrEmpty(e.Data))
sb.Append(e.Data);
});
p.Start();
p.BeginErrorReadLine();
string output = p.StandardOutput.ReadToEnd();
p.WaitForExit();
// Important:
// Display or log the output here. stdout output is available in variable "output";
// stderr is available in sb.ToString()
if (p.ExitCode != 0)
throw new Exception(String.Format("Non-zero return code {0}",
p.ExitCode));
}
此代码适用于任何发出输出的exe。
还有一个方法(此处未显示)从wzzip.exe输出中删除退格。当向人类显示字符串时,它更容易理解输出 - 就像在MessageBox或其他任何东西中一样。检查该方法的TestUtilities代码。
ps:只是重读你的Q,我看到你提到winzip32.exe。我不知道winzip32.exe是什么。 winzip发布的工具的命令行版本是wzzip.exe。我对输出和退格的评论适用于该工具。