使用wmi显示rpc服务器不可用,WMI:“RPC服务器不可用”错误只为域用户

我试图执行机器B(域的一部分)从机器A(不是域的一部分)的程序。当我尝试使用属于计算机B的管理员组的一部分的域用户时,我有以下代码并引发“RPC服务器不可用”。当我使用本地用户“管理员”,这也是机器B的管理员组的一部分,代码工作正常。WMI:“RPC服务器不可用”错误只为域用户

两台机器都禁用了防火墙。我可以使用这两个用户从机器A登录到机器B.

你能帮我吗?

ConnectionOptions connectionOptions = new ConnectionOptions();

connectionOptions.Authority = "kerberos:" + domain + @"\" + machine;

connectionOptions.Impersonation = ImpersonationLevel.Impersonate;

connectionOptions.Authentication = AuthenticationLevel.PacketPrivacy;

connectionOptions.Username = username;

connectionOptions.Password = password;

ManagementScope scope = new ManagementScope(@"\\" + machine + "." + domain + @"\root\CIMV2", connectionOptions);

ManagementPath p = new ManagementPath("Win32_Process");

ManagementClass classInstance = new ManagementClass(scope, p, null);

ManagementClass startupSettings = new ManagementClass("Win32_ProcessStartup");

startupSettings.Scope = scope;

startupSettings["CreateFlags"] = 16777216;

2013-02-21

Hem

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
你可以使用 Windows Management Instrumentation (WMI) 来获取 BIOS 版本。WMI 提供了许多可用于获取系统信息的类,其中一个是 Win32_BIOS 类,它提供了有关计算机上安装的 BIOS 的详细信息,包括 BIOS 版本。 以下是一个使用 WMI 获取 BIOS 版本的示例代码: ```c++ #include <Windows.h> #include <iostream> #include <comdef.h> #include <Wbemidl.h> #pragma comment(lib, "wbemuuid.lib") using namespace std; int main() { HRESULT hr = CoInitializeEx(NULL, COINIT_MULTITHREADED); if (FAILED(hr)) { cout << "Failed to initialize COM library. Error code: " << hr << endl; return 1; } hr = CoInitializeSecurity( NULL, -1, NULL, NULL, RPC_C_AUTHN_LEVEL_DEFAULT, RPC_C_IMP_LEVEL_IMPERSONATE, NULL, EOAC_NONE, NULL ); if (FAILED(hr)) { CoUninitialize(); cout << "Failed to initialize security. Error code: " << hr << endl; return 1; } IWbemLocator* pLoc = NULL; hr = CoCreateInstance( CLSID_WbemLocator, 0, CLSCTX_INPROC_SERVER, IID_IWbemLocator, (LPVOID*)&pLoc ); if (FAILED(hr)) { CoUninitialize(); cout << "Failed to create IWbemLocator object. Error code: " << hr << endl; return 1; } IWbemServices* pSvc = NULL; hr = pLoc->ConnectServer( _bstr_t(L"ROOT\\CIMV2"), NULL, NULL, 0, NULL, 0, 0, &pSvc ); if (FAILED(hr)) { pLoc->Release(); CoUninitialize(); cout << "Could not connect to WMI server. Error code: " << hr << endl; return 1; } hr = CoSetProxyBlanket( pSvc, RPC_C_AUTHN_WINNT, RPC_C_AUTHZ_NONE, NULL, RPC_C_AUTHN_LEVEL_CALL, RPC_C_IMP_LEVEL_IMPERSONATE, NULL, EOAC_NONE ); if (FAILED(hr)) { pSvc->Release(); pLoc->Release(); CoUninitialize(); cout << "Could not set proxy blanket. Error code: " << hr << endl; return 1; } IEnumWbemClassObject* pEnumerator = NULL; hr = pSvc->ExecQuery( _bstr_t("WQL"), _bstr_t("SELECT * FROM Win32_BIOS"), WBEM_FLAG_FORWARD_ONLY | WBEM_FLAG_RETURN_IMMEDIATELY, NULL, &pEnumerator ); if (FAILED(hr)) { pSvc->Release(); pLoc->Release(); CoUninitialize(); cout << "Could not execute query. Error code: " << hr << endl; return 1; } IWbemClassObject* pclsObj = NULL; ULONG uReturn = 0; while (pEnumerator) { hr = pEnumerator->Next(WBEM_INFINITE, 1, &pclsObj, &uReturn); if (uReturn == 0) { break; } VARIANT vtProp; hr = pclsObj->Get(L"Version", 0, &vtProp, 0, 0); if (SUCCEEDED(hr)) { wcout << "BIOS version: " << vtProp.bstrVal << endl; VariantClear(&vtProp); } pclsObj->Release(); } pSvc->Release(); pLoc->Release(); pEnumerator->Release(); CoUninitialize(); return 0; } ``` 该程序会输出当前计算机的 BIOS 版本号。需要注意的是,WMI 查询需要一定的权限,有些情况下需要以管理员身份运行程序。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值