1

我正在尝试创建一个在集中式设备上运行的小程序。该程序将运行

"psexec \server(s) netstat -na | findstr "LISTENING""

从远程节点收集 netstat 数据(应该将输出重定向到字符串),然后解析数据并与已知列表进行比较。我可以psexec从 cmd 行运行上面的 cmd 而不会出现任何问题,但是当我尝试在我的 C# 程序中运行与进程相同的命令时,没有返回数据进行解析。我可以看到netstat正在运行(cmd 窗口闪烁 netstat 结果),但 process.standardoutput 没有捕获流。如果我使用 ping 或其他任何东西psexec作为参数,流被捕获,结果显示在我的文本框中。我也尝试将文件名设置为 psexec.exe 并指定参数,但我得到了相同的结果。最后但并非最不重要的一点是,如果我在没有任何参数的情况下运行 psexec,我会在我的文本框中得到返回的帮助回扣信息。如果我psexec.exe作为文件名运行,或者如果我cmd.exe作为文件名运行且“/c psexec”指定为args.

我只是想在此时在本地执行时捕获 psexec 输出。稍后我会担心 psexec 到远程机器。任何帮助将非常感激。

这是代码:

        System.Diagnostics.Process pProcess = new System.Diagnostics.Process();  
        pProcess.StartInfo.FileName = "cmd.exe";  
        pProcess.StartInfo.Arguments = "/c psexec netstat";  
        pProcess.StartInfo.UseShellExecute = false;  
        pProcess.StartInfo.RedirectStandardOutput = true;     
        pProcess.Start();
        string strOutput = pProcess.StandardOutput.ReadToEnd(); 
        pProcess.WaitForExit();

        if (pProcess.HasExited)
        {
            textBox1.Text = strOutput;
        }
        else
        {
            textBox1.Text = "TIMEOUT FAIL";
        }
4

2 回答 2

3

我建议还捕获标准错误输出,以防那里报告任何内容。

此外,如果您在 64 位操作系统上运行,您可能会在 psexec 的“位”和您的应用程序之间存在脱节。如果是这种情况,请将项目的平台更改为匹配 psexec 的平台,而不是构建为 Any CPU。

于 2011-12-20T23:45:56.097 回答
2

遇到了一些需要更改的事情,但是您关于捕获标准错误输出的建议已经失效并且是一个好的开始。结果是一些信息被发送到错误输出(即使真的不是错误,只是从 psexec 运行状态 0)所以我知道那时 psexec 不只是吃掉所有的输出。一旦我开始尝试将远程主机作为参数传递,我就开始获取用户/传递错误数据。如果我想为 proc 运行提供凭据,还需要捕获标准输入。为远程执行添加一些 str 文字和凭据,效果很好。谢谢您的帮助。这是更新的代码-

        System.Diagnostics.Process pProcess = new System.Diagnostics.Process();
        pProcess.StartInfo.Domain = "domain";
        pProcess.StartInfo.UserName = "user with priv";
        pProcess.StartInfo.Password = new System.Security.SecureString();
        char [] pass = textBox3.Text.ToArray();
        for (int x = 0; x < pass.Length; ++x)
        {
            pProcess.StartInfo.Password.AppendChar(pass[x]);
        }
        pProcess.StartInfo.FileName = @"psexec.exe";
        pProcess.StartInfo.Arguments = @"\\remoteHost netstat -ano";
        pProcess.StartInfo.UseShellExecute = false;
        pProcess.StartInfo.RedirectStandardInput = true;
        pProcess.StartInfo.RedirectStandardOutput = true;
        pProcess.StartInfo.RedirectStandardError = true;
        pProcess.Start();
        pProcess.WaitForExit(30000);
        if (!pProcess.HasExited)
        {
            pProcess.Kill();
        }

        string strOutput = pProcess.StandardOutput.ReadToEnd();
        string errOutput = pProcess.StandardError.ReadToEnd();
        textBox1.Text = strOutput;
        textBox2.Text = errOutput;
于 2011-12-22T16:46:31.443 回答