4

我有一个以管理权限运行并调用dpinst.exe来执行自动驱动程序安装的进程(用 C# 编写)。它编写自己的自定义 dpinst.xml 文件来指定诸如禁止 EULA 页面、禁止向导、运行“安静安装”以及在所有子目录中搜索等内容。

当我从命令行手动调用它时(参见下面的示例),它似乎工作正常。由于我正在使用命令行开关,它会在控制台中打印一堆 INFO 级别的日志消息。

C:\Path\To\Drivers> dpinst.exe /C /L 0x409

我想记录控制台中打印的内容,所以我的 C# 代码如下所示:

var process = new Process
{
    StartInfo = new ProcessStartInfo
    {
        FileName = @"C:\Path\To\Drivers\dpinst.exe",
        Arguments = "/C /L 0x409",
        UseShellExecute = false,
        RedirectStandardOutput = true,
        CreateNoWindow = true,
        Verb = "runas"
    }
};

string output;
process.Start();

using (var reader = process.StandardOutput)
{
    output = reader.ReadToEnd();
    reader.Close();
}

但是,当我运行该代码时, 的值output始终为空。因此,对于我的下一个实验,我尝试直接使用命令行将输出通过管道传输到文件,如下所示:

C:\Path\To\Drivers> dpinst.exe /C /L 0x409 > test.log 2>&1

这创建了 test.log 文件,但它也是空白的。有趣的是,我仍然可以在同一个控制台窗口中看到 dpinst.exe 生成的所有控制台输出;由于某种原因,它没有被重定向到我指定的文件。因此,无论我如何调用 dpinst 可执行文件,症状都是相同的;它不想重定向输出。我不确定其根本原因是什么,也不知道如何解决。如何捕获控制台输出?

编辑:如果有人想要 dpinst.exe 的副本在本地运行并测试自己,我在这个链接上提供了一个,与我正在使用的 dpinst.xml 文件捆绑在一起。请记住,您需要使用/C命令行开关调用它才能生成任何命令行输出。或者,如果您偏执并且不想从一些随机的 Stack Overflow 问题中下载可执行文件,您可以从 Microsoft获取 dpinst.exe 实用程序作为Windows 驱动程序工具包的一部分。它是免费下载的,但您必须从完整的 WDK ISO(大约 700 MB)中提取实用程序(只有 500 KB)。由你决定。:)

4

2 回答 2

1

我的回答会帮助其他人。当您运行 Dpinst.exe 并添加 swicth /C 以将日志转储到控制台时,它还会在此目录“ C:\Windows\DPINST.LOG ”中创建一个日志文件

您可以在那里找到日志文件..

于 2018-08-29T20:41:35.070 回答
1

例如,您的代码可以使用标准工具(如“ping”)完美运行。所以也许出于某种原因 dpinst 改为写入标准错误?您可以设置 RedirectStandardError = true 并阅读 StandardError 以检查是否是这种情况。

更新以防其他人遇到此问题:

似乎 dpinst 不写入标准输出,而是以其他方式将消息记录到控制台。我想到的实现目标的唯一方法是:记住“%SystemRoot%\DPINST.LOG”文件的大小,运行命令,等待退出,然后读取记住的位置和文件结尾之间的所有内容。这样你就可以得到你的日志。

于 2015-09-09T16:20:44.130 回答