gpt4 book ai didi

asp.net-mvc - 如何调试 PowerShell 进程而不出现错误消息或异常

转载 作者:行者123 更新时间:2023-12-03 05:01:14 25 4
gpt4 key购买 nike

我正在尝试从我的 .NET 应用程序中运行以下 PowerShell 脚本:

try {
Start-Process "C:\Program Files (x86)\Google\Chrome\Application\chrome.exe" -ArgumentList "--headless --disable-gpu --print-to-pdf=c:\myDir\file.pdf https://www.bing.com"
$x = "Complete"
$x | Out-File C:\myDir\error.txt
}
Catch {
$_ | Out-File C:\myDir\error.txt
}

简单来说,上面将根据 bing.com 网站创建一个 pdf

在我的开发环境中,它作为 PowerShell 脚本运行良好。它在生产服务器上也运行良好(同样,作为 PowerShell 脚本)。

当我从生产服务器上的 Web 应用程序调用此 PowerShell 脚本时,会出现此问题。我的 C# 代码是

var command = "c:\myDir\ps.ps1";
ProcessStartInfo psi = new ProcessStartInfo();
psi.FileName = "powershell.exe";
psi.Arguments = command;
Process process = new Process();
process.StartInfo = psi;
process.Start();

这在我的开发机器上运行良好。它在生产服务器上失败。 error.txt 文件已写入光盘,这表明这不是权限问题。但是,error.txt 文件的内容始终显示“完整”。它永远不会出错。

因此,PowerShell 脚本中的捕获似乎从未被命中。因此,没有错误消息。 C#代码中没有抛出异常。无论如何,它不起作用。

如何调试这个?

或者,如果更简单的话,我很乐意直接运行代码,而不是调用 PowerShell 脚本文件,但以下内容也“什么也不做”。

 var command = $"\"C:\\Program Files (x86)\\Google\\Chrome\\Application\\chrome.exe\" -ArgumentList \"--no-sandbox --headless --disable-gpu --print-to-pdf={imagePath} {fullUrl}";

最佳答案

我能够重现您的问题。这是由于生产服务器上的 Web 应用程序正在以当前未登录的用户身份运行。它以分配的应用程序池的身份运行。 Chrome有known issue如果它在与当前登录用户不同的用户下启动,则无法正常工作。如果您检查该链接,您将看到该问题已于 2012 年 12 月注册,但仍未解决。如果在不同用户下启动 Chrome(按下 Shift 调用时快捷上下文菜单中的“以不同用户身份运行”),您可以轻松重现该问题。在这种情况下,Chrome 将不会打开任何页面,只会显示灰屏。

workaround是使用 --no-sandbox 开关启动 Chrome。谷歌实际上不推荐这样做。但是,如果您以自动方式运行 Chrome 来访问可信来源,我相信这是可以的。

因此,要解决该问题,请按以下方式修改脚本中的 start-process :

start-process "C:\Program Files (x86)\Google\Chrome\Application\chrome.exe" -ArgumentList "--no-sandbox --headless --disable-gpu --print-to-pdf=c:\myDir\file.pdf https://www.bing.com"

更新

一开始我低估了这个问题。现在,经过额外的研究和许多尝试的方法,我可以提出有效的解决方案。

我没有设法修复您当前从 Web 应用程序直接启动 powershell 和 chrome 的方法。 Chrome 无法启动,事件日志中出现以下错误:

Faulting application name: chrome.exe, version: 64.0.3282.186, time stamp: 0x5a8e38d5
Faulting module name: chrome_elf.dll, version: 64.0.3282.186, time stamp: 0x5a8e1e3d
Exception code: 0x80000003
Fault offset: 0x00000000000309b9
Faulting process id: 0x11524
Faulting application start time: 0x01d3bab1a89e3b4f
Faulting application path: C:\Program Files (x86)\Google\Chrome\Application\chrome.exe
Faulting module path: C:\Program Files (x86)\Google\Chrome\Application\64.0.3282.186\chrome_elf.dll
Report Id: e70a5a36-26a4-11e8-ac26-b8ca3a94ba80

即使您将应用程序池配置为使用可以启动 chrome 的某些现有(普通)用户的身份,也会发生此错误。也许可以配置 IIS 或应用程序池来防止这些错误,但我还没有找到方法。

我的建议是从从 Controller 操作启动 powershell 进程切换到使用 Windows 任务计划程序来计划任务。

以下是完成此任务应采取的步骤:

  1. 在您的生产服务器上创建一个用户,Chrome 将在该用户下启动。我将创建的用户称为“testuser”。
  2. testuser下登录,启动chrome,打开一些网站。如果没有此步骤,流程将不会成功,可能是因为缺少 Chrome 用户帐户。
  3. testuser 授予“作为批处理作业登录”权限。要成功执行 testuser 下的计划任务,需要执行此步骤。 this answer 中描述了该过程。
  4. 按照我在最初的回答中所述,将 --no-sandbox 参数添加到脚本中。
  5. Process.Start() 代码替换为任务作业的调度。

The easiest way要从 .Net 安排任务,请通过 TaskScheduler NuGet 。将其安装到您的应用程序并添加以下代码:

string powerShellScript = @"c:\myDir\ps.ps1";
string userName = @"YOURCOMP\testuser";
string userPassword = "TestPwd123";

using (TaskService ts = new TaskService())
{
TaskDefinition td = ts.NewTask();
td.Triggers.Add(new RegistrationTrigger
{
StartBoundary = DateTime.Now,
EndBoundary = DateTime.Now.AddMinutes(1),
});
td.Settings.DeleteExpiredTaskAfter = TimeSpan.FromSeconds(5);
td.Actions.Add(new ExecAction("powershell.exe", powerShellScript));
ts.RootFolder.RegisterTaskDefinition($@"Print Pdf - {Guid.NewGuid()}", td, createType: TaskCreation.Create, userId: userName, password: userPassword, logonType: TaskLogonType.Password);
}

在上面的代码片段中更改 testuser 的名称和密码。

通过这种方法,您的脚本已成功执行,并且 pdf 已成功打印。

OP更新

如果上述操作仍然失败,请再次检查事件查看器日志。在这种情况下,我遇到了类似于以下消息的问题:计算机默认权限设置不会为 CLSID {20FD4E26-8E0F-4F73-A0E0-F27B8C57BE6F} 且 APPID 不可用<的 COM 服务器应用程序授予本地激活权限 但通过授予 permissions for the CLSID 解决了这个问题。此外,尝试在任务计划程序中单独运行任务,例如创建一个新任务来简单地启动记事本或类似任务,以确保它适用于您要测试的帐户。就我而言,我必须使用管理员帐户。

关于asp.net-mvc - 如何调试 PowerShell 进程而不出现错误消息或异常,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49094779/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com