WMI(Windows Management Instrumentation)是Windows下可以与系统信息(包括软硬件等)的一个管理框架,通过WMI可以很方便地对机器进行管理。现在以通过WMI来打开(或创建)一个记事本(notepad.exe)进程为例,看看VC++到.Net的变迁,一览.Net是如何让程序员从繁琐晦涩的程序中解放出来。

1、预工作:
VC++中需要在源代码中加入:
#include <Wbemidl.h>
#pragma comment(lib, "wbemuuid.lib")

VC#中需要:
在工程中添加引用:System.Management
在代码中加入using System.Management;

2、流程:
VC++的代码,需要6步和查询返回值、最后释放资源:
从WMI看VC++到.Net的变迁// Step 1: --------------------------------------------------
从WMI看VC++到.Net的变迁
// Initialize COM. ------------------------------------------
从WMI看VC++到.Net的变迁
hres =  CoInitializeEx(0, COINIT_MULTITHREADED); 
从WMI看VC++到.Net的变迁

从WMI看VC++到.Net的变迁// Step 2: --------------------------------------------------
从WMI看VC++到.Net的变迁
// Set general COM security levels --------------------------
从WMI看VC++到.Net的变迁
hres =  CoInitializeSecurity(
从WMI看VC++到.Net的变迁        NULL, 
从WMI看VC++到.Net的变迁        
-1,                          // COM negotiates service
从WMI看VC++到.Net的变迁
        NULL,                        // Authentication services
从WMI看VC++到.Net的变迁
        NULL,                        // Reserved
从WMI看VC++到.Net的变迁
        RPC_C_AUTHN_LEVEL_DEFAULT,   // Default authentication 
从WMI看VC++到.Net的变迁
        RPC_C_IMP_LEVEL_IMPERSONATE, // Default Impersonation  
从WMI看VC++到.Net的变迁
        NULL,                        // Authentication info
从WMI看VC++到.Net的变迁
        EOAC_NONE,                   // Additional capabilities 
从WMI看VC++到.Net的变迁
        NULL                         // Reserved
从WMI看VC++到.Net的变迁
        );

从WMI看VC++到.Net的变迁// Step 3: ---------------------------------------------------
从WMI看VC++到.Net的变迁
// Obtain the initial locator to WMI -------------------------
从WMI看VC++到.Net的变迁
IWbemLocator *pLoc = NULL;
从WMI看VC++到.Net的变迁hres 
= CoCreateInstance(
从WMI看VC++到.Net的变迁        CLSID_WbemLocator,             
从WMI看VC++到.Net的变迁        
0
从WMI看VC++到.Net的变迁        CLSCTX_INPROC_SERVER, 
从WMI看VC++到.Net的变迁        IID_IWbemLocator, (LPVOID 
*&pLoc);
从WMI看VC++到.Net的变迁

从WMI看VC++到.Net的变迁// Step 4: ---------------------------------------------------
从WMI看VC++到.Net的变迁
// Connect to WMI through the IWbemLocator::ConnectServer method
从WMI看VC++到.Net的变迁
IWbemServices *pSvc = NULL;
从WMI看VC++到.Net的变迁
// Connect to the local root\cimv2 namespace
从WMI看VC++到.Net的变迁
// and obtain pointer pSvc to make IWbemServices calls.
从WMI看VC++到.Net的变迁
hres = pLoc->ConnectServer(
从WMI看VC++到.Net的变迁        _bstr_t(L
"ROOT\\CIMV2"), 
从WMI看VC++到.Net的变迁        NULL,
从WMI看VC++到.Net的变迁        NULL, 
从WMI看VC++到.Net的变迁        
0
从WMI看VC++到.Net的变迁        NULL, 
从WMI看VC++到.Net的变迁        
0
从WMI看VC++到.Net的变迁        
0
从WMI看VC++到.Net的变迁        
&pSvc
从WMI看VC++到.Net的变迁    );
从WMI看VC++到.Net的变迁

从WMI看VC++到.Net的变迁// Step 5: --------------------------------------------------
从WMI看VC++到.Net的变迁
// Set security levels for the proxy ------------------------
从WMI看VC++到.Net的变迁
hres = CoSetProxyBlanket(
从WMI看VC++到.Net的变迁        pSvc,                        
// Indicates the proxy to set
从WMI看VC++到.Net的变迁
        RPC_C_AUTHN_WINNT,           // RPC_C_AUTHN_xxx 
从WMI看VC++到.Net的变迁
        RPC_C_AUTHZ_NONE,            // RPC_C_AUTHZ_xxx 
从WMI看VC++到.Net的变迁
        NULL,                        // Server principal name 
从WMI看VC++到.Net的变迁
        RPC_C_AUTHN_LEVEL_CALL,      // RPC_C_AUTHN_LEVEL_xxx 
从WMI看VC++到.Net的变迁
        RPC_C_IMP_LEVEL_IMPERSONATE, // RPC_C_IMP_LEVEL_xxx
从WMI看VC++到.Net的变迁
        NULL,                        // client identity
从WMI看VC++到.Net的变迁
        EOAC_NONE                    // proxy capabilities 
从WMI看VC++到.Net的变迁
    );

从WMI看VC++到.Net的变迁// Step 6: --------------------------------------------------
从WMI看VC++到.Net的变迁
// Use the IWbemServices pointer to make requests of WMI ----
从WMI看VC++到.Net的变迁
// set up to call the Win32_Process::Create method
从WMI看VC++到.Net的变迁
BSTR MethodName = SysAllocString(L"Create");
从WMI看VC++到.Net的变迁BSTR ClassName 
= SysAllocString(L"Win32_Process");
从WMI看VC++到.Net的变迁
从WMI看VC++到.Net的变迁IWbemClassObject
* pClass = NULL;
从WMI看VC++到.Net的变迁hres 
= pSvc->GetObject(ClassName, 0, NULL, &pClass, NULL);
从WMI看VC++到.Net的变迁
从WMI看VC++到.Net的变迁IWbemClassObject
* pInParamsDefinition = NULL;
从WMI看VC++到.Net的变迁hres 
= pClass->GetMethod(MethodName, 0
从WMI看VC++到.Net的变迁        
&pInParamsDefinition, NULL);
从WMI看VC++到.Net的变迁
从WMI看VC++到.Net的变迁IWbemClassObject
* pClassInstance = NULL;
从WMI看VC++到.Net的变迁hres 
= pInParamsDefinition->SpawnInstance(0&pClassInstance);
从WMI看VC++到.Net的变迁
从WMI看VC++到.Net的变迁
// Create the values for the in parameters
从WMI看VC++到.Net的变迁
VARIANT varCommand;
从WMI看VC++到.Net的变迁varCommand.vt 
= VT_BSTR;
从WMI看VC++到.Net的变迁varCommand.bstrVal 
= L"notepad.exe";
从WMI看VC++到.Net的变迁
// Store the value for the in parameters
从WMI看VC++到.Net的变迁
hres = pClassInstance->Put(L"CommandLine"0,
从WMI看VC++到.Net的变迁        
&varCommand, 0);
从WMI看VC++到.Net的变迁wprintf(L
"The command is: %s\n", V_BSTR(&varCommand));
从WMI看VC++到.Net的变迁
从WMI看VC++到.Net的变迁
// Execute Method
从WMI看VC++到.Net的变迁
IWbemClassObject* pOutParams = NULL;
从WMI看VC++到.Net的变迁hres 
= pSvc->ExecMethod(ClassName, MethodName, 0, NULL, pClassInstance, &pOutParams, NULL);
从WMI看VC++到.Net的变迁

从WMI看VC++到.Net的变迁// Get return value
从WMI看VC++到.Net的变迁
VARIANT varReturnValue;
从WMI看VC++到.Net的变迁hres 
= pOutParams->Get(_bstr_t(L"ReturnValue"), 0&varReturnValue, NULL, 0);
从WMI看VC++到.Net的变迁
从WMI看VC++到.Net的变迁
// Last: clean up
从WMI看VC++到.Net的变迁
VariantClear(&varCommand);
从WMI看VC++到.Net的变迁VariantClear(
&varReturnValue);
从WMI看VC++到.Net的变迁SysFreeString(ClassName);
从WMI看VC++到.Net的变迁SysFreeString(MethodName);
从WMI看VC++到.Net的变迁pClass
->Release();
从WMI看VC++到.Net的变迁pInParamsDefinition
->Release();
从WMI看VC++到.Net的变迁pOutParams
->Release();
从WMI看VC++到.Net的变迁pLoc
->Release();
从WMI看VC++到.Net的变迁pSvc
->Release();
从WMI看VC++到.Net的变迁CoUninitialize();

VC#只需寥寥数行就可以实现(暂不考虑错误处理):
跳过VC++中的Step1~5,直接从Step6开始。而且非常直观:
从WMI看VC++到.Net的变迁ManagementClass mc = new  ManagementClass("Win32_Process");
从WMI看VC++到.Net的变迁ManagementBaseObject obj 
= mc.GetMethodParameters("Create");
从WMI看VC++到.Net的变迁obj[
"CommandLine"]="notepad.exe";
从WMI看VC++到.Net的变迁mc.InvokeMethod(
"Create", obj, null);
从WMI看VC++到.Net的变迁mc.Dispose();从WMI看VC++到.Net的变迁

.Net对WMI良好的封装,还有对字符串的更强支持、方便的垃圾回收机制,使程序既一目了然,又易于维护。其实类似的区别在VC vs VB年代已经出现了(特别是在COM组件编写和调用方面可以看出),从这点也可以看出.Net完全继承了VB易学易用的特性,又不失强大的功能。

相关文章:

  • 2022-02-07
  • 2022-12-23
  • 2021-10-02
  • 2022-03-05
  • 2022-02-26
  • 2021-10-06
猜你喜欢
  • 2022-12-23
  • 2022-12-23
  • 2021-07-30
  • 2021-09-23
  • 2021-07-25
  • 2021-11-29
相关资源
相似解决方案