WMI代码生成器怎么使用 WMI Code Creator使用详细图文教程

WMI是一种轻松获取系统信息的强大工具。利用它但是由于缺少WMI的介绍资料和学习资料(特别是中文的,因为国内大部分程序员的E文水平都比较凑合,呵呵,本人也是相当凑合),所以知道WMI的不多,能运用的就少之又少了。

WMI Code Creator是微软提供的一个WMI代码生成工具,这篇文章主要是介绍WMI Code Creator的用法的。首先说明这个软件是在.net Framework 2.0下编译的,所以在运行软件是需要.net Framework 2.0支持。

WMI代码生成器的界面如下:

利用WMI代码生成器可以执行查询或者执行一个方法等,还可以查看当前或者远程电脑上的命名空间以及其下的类,并且还可以生成相关的代码(不然就不叫WMI代码生成器了),支持生成的代码类型包括VBS、C#及VB.NET,默认生成的代码是VBS。

例如要想查询BIOS的相关信息,可以在命名空间处选择root\CIMV2(这个是默认选择),然后在全部类处选择Win32_BIOS,这时就会列出Win32_BIOS类的所有属性,可以选择其中一个属性然后点击“查询属性值”,就会在下面的文本框中列出该属性的值,如下图所示:

从上图中可以看出本人的本本BIOS是DELL的,在右侧生成代码处可以看到相关的VBS代码,如果看默认生成的VBS代码不爽可以换成C#或者VB.NET的,具体操作就是在“编程语言”菜单处选择,如下图所示:

下面是选择目标编程语言为C#后生成的代码,如下图所示:

WMI代码生成器默认是连接到本地机器,不过也提供了连接远程主机或者主机组的功能,这个可以在目标机器中选择。如下图所示。

由于本人已经将常用操作部分汉化了(可能不是十分准确),所以操作起来相对较容易上手。

说明:由于在后台多处使用了线程池来进行操作,所以在执行一些耗时的操作而没有等待完全结束退出软件时会报异常。另外,在汉化的过程中有些不常用部分并没有完全汉化,并且有些地方翻译不是十分准确,敬请原谅,使用本软件时结果仅供参考。如果您的英语足够好建议您到微软英文官方网站下载英文的代码并自行编译(整个软件全部包含在一个cs文件中,需要在命令行下编译),本软件仅仅为那些英语不十分过关的朋友提供一些小小的帮助。

.net中的WMI编程实例:

在WMI中有一种查询语言,类似于SQL语言,这种语言叫做WQL(WMI Query Language),实际上是标准SQL的一个子集加上了WMI的扩展。在接下来的教程中我会给大家演示一些WQL的例子。

用js或者vbs都可以通过WMI来获取系统信息。下面是一个用vbs编写的获取系统序列号的小程序,你可以把它复制到一个文本文件里,然后保存为文件为.vbs的文件,然后运行:

Set SNSet = GetObject("winmgmts:").InstancesOf ("Win32_OperatingSystem")

for each SN in SNSet

MsgBox "当前操作系统的序列号是: " & SN.SerialNumber

这是在我的机子上运行的结果:

如果通过常规手段在.net里让你写这个方法不知道你需要多少行代码?需要利用几次搜索引擎?一会我将展示如何在.net里利用WMI获取操作系统序列号。

其实在.net里是支持WMI编程的,在.net类库里专门有一个System.Management 命名空间,MSDN介绍这个命名空间如下:

“提供对大量管理信息和管理事件集合的访问,这些信息和事件是与根据 Windows 管理规范 (WMI) 结构对系统、设备和应用程序设置检测点有关的。应用程序和服务可以使用从 ManagementObjectSearcher 和 ManagementQuery 派生的类,查询感兴趣的管理信息(例如在磁盘上还剩多少可用空间、当前 CPU 利用率是多少、某一应用程序正连接到哪一数据库等等);或者应用程序和服务可以使用 ManagementEventWatcher 类预订各种管理事件。这些可访问的数据可以来自分布式环境中托管的和非托管的组件。”。

System.Management 命名空间包含了下面一些常用类:

◆ManagementObject 或 ManagementClass:分别为单个管理对象或类。

◆ManagementObjectSearcher:用于根据指定的查询或枚举检索 ManagementObject 或 ManagementClass 对象的集合。

◆ManagementEventWatcher:用于预订来自 WMI 的事件通知。

◆ManagementQuery:用作所有查询类的基础。

在实际编程中需要注意,System.Management 命名空间中的类都存在于System.Management .dll这个文件中,所以在编程的时候一定要添加对这个dll文件的引用,如下图:

然后还需要在我们的程序开始处添加如下代码:System.Management,这样我们采用使用这个命名空间下的类来进行WMI编程。

下面我将用一个方法展示我刚才提到的如何在.net里获取操作系统序列号:

/// <summary>

/// 获取操作系统序列号

/// </summary>

/// <returns></returns>

public string GetSerialNumber()

{

string result = "";

ManagementClass mClass = new ManagementClass("Win32_OperatingSystem");

ManagementObjectCollection moCollection = mClass.GetInstances();

foreach (ManagementObject mObject in moCollection)

{

result += mObject["SerialNumber"].ToString();

}

return result;

}

我想这个方法够简单的了。

下面贴出一些常用的方法来获取系统相关的信息,代码如下:

using System;

using System.Collections.Generic;

using System.Text;

namespace WMIDemo

{

/// <summary>

/// 说明:这个类很简单,主要包含一个Main方法

/// 作者:周公

/// 日期:2008-1-14

/// 首发地址:http://blog.csdn.net/zhoufoxcn

/// </summary>

class Program

{

static void Main(string[] args)

{

GetSystemInfo getInfo = new GetSystemInfo();

Console.WriteLine("序列号="+getInfo.GetSerialNumber());

Console.WriteLine("CPU编号=" + getInfo.GetCpuID());

Console.WriteLine("硬盘编号=" + getInfo.GetMainHardDiskId());

Console.WriteLine("主板编号=" + getInfo.GetMainBoardId());

Console.WriteLine("网卡编号=" + getInfo.GetNetworkAdapterId());

Console.WriteLine("用户组=" + getInfo.GetGroupName());

Console.WriteLine("驱动器情况=" + getInfo.GetDriverInfo());

Console.ReadLine();

}

}

}

由于是一个命令行程序,所以有上面那个类,下面这个类才包含我要展示的代码:

using System;

using System.Collections.Generic;

using System.Text;

using System.Management;

namespace WMIDemo

{

/// <summary>

/// 说明:这个类主要用来展示如何利用WMI来获取一些操作系统的信息

/// 作者:周公

/// 时间:2008-1-14

/// 首发地址:http://blog.csdn.net/zhoufoxcn

/// </summary>

public class GetSystemInfo

{

/// <summary>

/// 获取操作系统序列号

/// </summary>

/// <returns></returns>

public string GetSerialNumber()

{

string result = "";

ManagementClass mClass = new ManagementClass("Win32_OperatingSystem");

ManagementObjectCollection moCollection = mClass.GetInstances();

foreach (ManagementObject mObject in moCollection)

{

result += mObject["SerialNumber"].ToString() + " ";

}

return result;

}

/// <summary>

/// 查询CPU编号

/// </summary>

/// <returns></returns>

public string GetCpuID()

{

string result = "";

ManagementClass mClass = new ManagementClass("Win32_Processor");

ManagementObjectCollection moCollection = mClass.GetInstances();

foreach (ManagementObject mObject in moCollection)

{

result += mObject["ProcessorId"].ToString() + " ";

}

return result;

}

/// <summary>

/// 查询硬盘编号

/// </summary>

/// <returns></returns>

public string GetMainHardDiskId()

{

string result = "";

ManagementObjectSearcher searcher = new ManagementObjectSearcher("SELECT * FROM Win32_PhysicalMedia");

ManagementObjectCollection moCollection = searcher.Get();

foreach (ManagementObject mObject in moCollection)

{

result += mObject["SerialNumber"].ToString() + " ";

}

return result;

}

/// <summary>

/// 主板编号

/// </summary>

/// <returns></returns>

public string GetMainBoardId()

{

string result = "";

ManagementObjectSearcher searcher = new ManagementObjectSearcher("root/CIMV2",

"SELECT * FROM Win32_BaseBoard");

ManagementObjectCollection moCollection = searcher.Get();

foreach (ManagementObject mObject in moCollection)

{

result += mObject["SerialNumber"].ToString() + " ";

}

return result;

}

/// <summary>

/// 主板编号

/// </summary>

/// <returns></returns>

public string GetNetworkAdapterId()

{

string result = "";

ManagementObjectSearcher searcher = new ManagementObjectSearcher("SELECT MACAddress FROM Win32_NetworkAdapter WHERE ((MACAddress Is Not NULL)AND (Manufacturer <> 'Microsoft'))");

ManagementObjectCollection moCollection = searcher.Get();

foreach (ManagementObject mObject in moCollection)

{

result += mObject["MACAddress"].ToString() + " ";

}

return result;

}

/// <summary>

/// 主板编号

/// </summary>

/// <returns></returns>

public string GetGroupName()

{

string result = "";

ManagementObjectSearcher searcher = new ManagementObjectSearcher("root/CIMV2", "SELECT * FROM Win32_Group");

ManagementObjectCollection moCollection = searcher.Get();

foreach (ManagementObject mObject in moCollection)

{

result += mObject["Name"].ToString() + " ";

}

return result;

}

/// <summary>

/// 获取本地驱动器信息

/// </summary>

/// <returns></returns>

public string GetDriverInfo()

{

string result = "";

ManagementObjectSearcher searcher = new ManagementObjectSearcher("root/CIMV2", "SELECT * FROM Win32_LogicalDisk");

ManagementObjectCollection moCollection = searcher.Get();

foreach (ManagementObject mObject in moCollection)

{

//mObject["DriveType"]共有6中可能值,分别代表如下意义:

//1:No type   2:Floppy disk   3:Hard disk

//4:Removable drive or network drive   5:CD-ROM   6:RAM disk

//本处只列出固定驱动器(硬盘分区)的情况

if (mObject["DriveType"].ToString() == "3")

{

result += string.Format("Name={0},FileSystem={1},Size={2},FreeSpace={3} ", mObject["Name"].ToString(),

mObject["FileSystem"].ToString(), mObject["Size"].ToString(), mObject["FreeSpace"].ToString());

}

}

return result;

}

}

}

程序的运行结果如下(不同机器上的结果会不相同):

最后说明:虽然绝大部分Windows操作系统已经安装了WMI(根据微软官方说法是自WinME以后的Windows系统包括WinME都安装了),但是不能保证上面的代码能在所有的Windows操作系统之上,如Win95之类,如果在不支持WMI的Windows系统上运行WMI,那么需要从MSDN下载WMI。

另外,运行WMI需要当前Windows登录用户有一定的权限,由于本人开发时是以管理员的身份登录并运行程序的,所以没有权限异常提示,但是我不保证代码在你处运行也正常,特别是在WebForm的环境下,因为asp.net程序默认是较低的权限运行的(安全原因)。

(0)

相关推荐