尝试在 C# / ASP.NET / IIS 7.5 / Win7 环境中调用可执行命令提示符
在服务器上,我尝试打开命令提示符并调用将文件转换为 PDF 的可执行文件。为此,我使用 PDFCreator 开源程序。
在 C# 中,我使用以下代码进行调用:
ProcessStartInfo processStartInfo = new ProcessStartInfo("cmd.exe");
processStartInfo.RedirectStandardInput = true;
processStartInfo.RedirectStandardOutput = true;
processStartInfo.UseShellExecute = false;
Process process = Process.Start(processStartInfo);
process.StandardInput.WriteLine(@"cd c:\program files (x86)\pdfcreator");
process.StandardInput.WriteLine(@"PDFCreator.exe /PF""c:\dwf\dwf.dwf""");
它运行时没有错误,但没有产生任何结果。 PDFCreator.exe 的作用是调用另一个程序 Autodesk Design Review,该程序将打开、使用 PDF 驱动程序打印为 PDF,然后保存文件。您看到的命令在我独立运行时工作正常。
从搜索其他线程看来,安全性可能是我的问题。因此,我已转到 PDFCreator 和 Design Review 文件夹/可执行文件,并授予对 NETWORK、NETWORK SERVICE、IIS_WPG、IIS_IUSRS 和 ASP.NET Machine 帐户的完全访问权限(意识到这可能是一个安全线程,但一旦我弄清楚来源,就会禁用)的问题)。这并没有帮助。
应该注意的是,我可以使用上面的第一个命令更改目录,然后在 PDFCreator 和 Design Review 文件夹中创建一个“test123”文件夹。看来我已经接近这里了,有什么想法吗?
On the server, I'm attempting to open the command prompt and call an executable which converts a file to PDF. For this I am using the PDFCreator open source program.
In C# I am calling with this code:
ProcessStartInfo processStartInfo = new ProcessStartInfo("cmd.exe");
processStartInfo.RedirectStandardInput = true;
processStartInfo.RedirectStandardOutput = true;
processStartInfo.UseShellExecute = false;
Process process = Process.Start(processStartInfo);
process.StandardInput.WriteLine(@"cd c:\program files (x86)\pdfcreator");
process.StandardInput.WriteLine(@"PDFCreator.exe /PF""c:\dwf\dwf.dwf""");
It runs with no error, yet yields no result. What this PDFCreator.exe does is call another program, Autodesk Design Review which opens, uses the PDF driver to print to PDF, and saves the file. The command you see works fine being running standalone by me.
From scouring other threads it seems security could be my issue. So I have gone to the PDFCreator and Design Review folders/executables and granted full access to NETWORK, NETWORK SERVICE, IIS_WPG, IIS_IUSRS, and ASP.NET Machine account (realize this is probably a security thread but will disable once i figure out source of the issue). This has not helped.
It should be noted than i can change directory using the first command above, and then create a "test123" folder in both PDFCreator and Design Review folders. Seems I am getting close here, any ideas?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(4)
SteveCalPoly 和 Val Akkapeddi 的评论非常有趣。
无论如何,我使用以下方法通过命令提示符运行可执行文件
SteveCalPoly and Val Akkapeddi comments are very interesting.
Anyway, I use the following methods to run executable with command prompt
System.Diagnostics.Process 类有一个名为 WaitForExit() 的方法,该方法将等待其启动的进程退出后再继续,然后返回其返回代码。
尝试使用命令创建批处理文件,然后通过 Process 类运行批处理文件。如果使用 Process.WaitForExit(); 会发生什么?调用 Process.Start(processInfo); 后? process.WaitForExit() 是否有返回码?
The System.Diagnostics.Process class has a method called WaitForExit() which will wait for its launched process to exit before continuing and then will return its return code.
Try creating a batch file with your commands and then running the batch file via the Process class. What happens if you use Process.WaitForExit(); after you call Process.Start(processInfo); ? Is there a return code from process.WaitForExit() at all?
也许错误会发送到 StandardError 流,所以您永远不会看到它们?
另外,为什么不直接调用 PDFCreator.exe 而不是通过 cmd.exe 调用呢?
尝试这样的事情
Perhaps the errors are going to the StandardError stream and so you never see them?
Also, why not call PDFCreator.exe directly instead of via cmd.exe?
Try something like this
在 serverfault 发现了这个问题。我调用的应用程序需要在桌面上打开另一个应用程序,然后打印为 PDF。除非在
services --> 中设置,否则 IIS 无法打开桌面上的程序服务名称-->登录
选项卡。不幸的是,我调用的应用程序不在服务面板中,所以我目前再次陷入困境,但至少我知道这不是 C# 问题。
Found out the issue over at serverfault. The app I was calling needs to open another app on the desktop and then print to PDF. IIS cannot open programs on the desktop unless set in the
services --> service name --> log
on tab.Unfortunately, the app I am calling isn't in the services panel so I'm currently stuck again, but at least I know it's not a C# problem.