3

我目前正在使用 C# 中的 P/Invoke 使用 CreateProcessAsUser,以便从 SYSTEM 帐户中运行的 Windows 服务作为受限用户启动进程。

我的目标是有一个服务来启动一个应用程序,该应用程序需要从我们办公室的用户那里获取信息(进程在前台运行、时间空闲等)。问题是如果这个应用程序以用户的权限运行......好吧,他可以关闭它。如果像其他应用程序的常规进程一样运行,我可以通过以下方式控制此重生:

ProcessStartInfo psi = new ProcessStartInfo();
psi.FileName = ExePath;
psi.UseShellExecute = false;

Process p = new Process();
p.StartInfo = psi;
p.EnableRaisingEvents = true;
p.Exited += new EventHandler(LaunchAgain);
p.Start();

但是这样,我的问题是,我有两个用户可关闭的应用程序,而不是用户可关闭的应用程序(嗯,但其中一个会重新生成另一个:P)。

您是否知道有某种方法可以知道CreateProcessAsUser创建的进程是否可以被“监视”以在它被杀死或终止时启动某些操作?

PD:当然,不要提出任何改进或不同的方法。

4

2 回答 2

1

两件事 - CreateProcessAsUser 有一个参数lpProcessInformation,用于接收有关新进程的数据。然后,您可以等待进程句柄。或者,您可以通过 Process.GetProcessById(...) 创建一个 C# 进程类,并像上面的代码片段一样使用它。

OTOH,直接从您的服务中执行功能(收集信息 - 如果我理解正确的话)可能会更简单。

于 2013-05-24T10:19:52.377 回答
1

我终于设法解决了:

ProcessRunner runner = new ProcessRunner(Path, hSessionToken);
runner.Run();
this.Launch(context);

在我的 ProcessRunner 类中,我使用了类似的东西:

CreateProcessAsUser(this.mSessionTokenHandle, this.mApplicationPath, this.CommandLine, IntPtr.Zero, IntPtr.Zero, 0, creationFlags, envBlock, this.WorkingDirectory, si, pi);
ProcessWaitHandle waitable = new ProcessWaitHandle(pi.hProcess);
if (waitable.WaitOne())
{
    return;
}  

因为WaitOne在收到信号时返回 true。

这是我摆弄等待句柄的课程。

internal class ProcessWaitHandle : WaitHandle
{
    public ProcessWaitHandle(IntPtr processHandle)
    {
        this.SafeWaitHandle = new SafeWaitHandle(processHandle, false);
    }
}

感谢 JeffRSon 提出使用手柄的想法。

于 2013-05-27T17:30:57.303 回答