2

我正在编写一些代码来在远程机器上进行 wmi 查询和方法执行。我的登录凭据是域管理员。当我在应用程序模式下运行时,一切正常。当我作为服务运行时,它将无法正常工作,因为默认帐户服务使用 isLocal System。当我将服务设置为作为我的凭据运行时,远程 wmi 也可以正常工作。

然而这是不可取的,所以我试图通过在 IWbemLocator.ConnectServer 提供用户名和密码来连接到远程 wmi。我能够成功取回 IWbemServices 对象。但是,当我尝试从 IWbemServices 对象获取类对象时,出现错误:

//IWbemServices *pSvc
const bstr_t objectPath("stdRegProv");
const bstr_t methodName("GetStringValue");
IWbemClassObject *pClass = NULL;
HRESULT hr = pSvc->GetObject(objectPath, 0, NULL, &pClass, NULL);

返回的 hr 是 0x80041003,即来自此链接的“访问被拒绝”:http: //msdn.microsoft.com/en-us/library/windows/desktop/aa394559%28v=vs.85%29.aspx

通常,如果我提供了错误的用户名和密码,我会在 IWbemLocator.ConnectServer 上拒绝访问。所以我在这里有点困惑为什么连接很好但是我无法获得 IWbemClassObject 对象。由于如果我使用我的域凭据作为服务帐户它可以工作,因此必须存在一些安全差异。我的 WMI 连接代码基于 MSDN 上的示例代码:http: //msdn.microsoft.com/en-us/library/windows/desktop/aa390418%28v=vs.85%29.aspx

4

1 回答 1

1

WMI 类型剥夺了一些安全权利;您需要将您的帐户设置为“受信任的委托”,这是非常强大且不推荐的,或者签署您的代码。或者,您可以将显式权限传递给进程。

于 2012-10-28T05:04:43.823 回答