【发布时间】:2010-09-26 14:33:38
【问题描述】:
是否可以使用不同的用户帐户在 Windows 上创建新进程?我知道有一个上下文菜单“运行方式”,但我想用 Java 来做。我有用户名和密码。
【问题讨论】:
标签: java windows process account
是否可以使用不同的用户帐户在 Windows 上创建新进程?我知道有一个上下文菜单“运行方式”,但我想用 Java 来做。我有用户名和密码。
【问题讨论】:
标签: java windows process account
我刚刚遇到了一个名为 MiniRunAs 的 runas.exe 程序的替代方案,它将在命令行上获取密码 - http://www.source-code.biz/snippets/c/1.htm
如果您能够将它与您的应用程序一起安装,那可能比编写 JNI DLL 更简单。
【讨论】:
根据您的需要,Win32 API“CreateProcessWithLogonW”比“CreateProcessAsUser / LogonUser”函数更易于使用。
来自 MSDN 文档:
CreateProcessWithLogonW 和 CreateProcessWithTokenW 函数是 类似于 CreateProcessAsUser 函数,不同之处在于调用者 不需要调用 LogonUser 函数来验证用户 并获得一个令牌【讨论】:
RUNAS 具有“/savecred”开关,可让您仅在第一次输入凭据。一个潜在的问题是,当 /SaveCred 保存凭据时,它会在 RUNAS 调用该用户帐户时保存它。这可能是一个巨大的安全风险,所以要小心使用它!
【讨论】:
您需要使用Java Native Interface (JNI) 编写一个 DLL,因为您无法使用纯 Java 代码执行此操作。
DLL 本身需要调用 CreateProcessAsUser 函数来在另一个用户的上下文中创建一个进程。要成功创建该进程,您需要向函数提供访问令牌,该令牌本身是通过调用 LogonUser 函数创建的(它需要用户名和密码来验证其他用户)。
【讨论】:
有一个名为“runas.exe”的程序。您可以运行该进程并为您的进程和用户名/密码提供适当的参数。我认为这是最简单的方法。
【讨论】: