最近更新|软件分类|软件专题|软件排行|手机版|软件发布WMI Code Creator中文版 v1.0 绿色版
您的位置:首页>编程开发 > 编程工具>WMI Code Creator中文版 v1.0 绿色版

WMI Code Creator中文版 v1.0 绿色版WMI代码生成器

网友评分:

相关软件

软件介绍

WMI Code Creator中文版是一款非常专业的WMI代码生成器,而且利用WMI代码生成器可以执行查询或者执行一个方法等,下面小编为大家带来汉化版,欢迎下载使用!

软件介绍

WMI Code Creator是由微软推出的一款功能强大的WMI代码生成器,利用WMI代码生成器可以执行查询或者执行一个方法等,还可以查看当前或者远程电脑上的命名空间以及其下的类,并且还可以生成相关的代码,支持生成的代码类型包括VBS、C#及VB.NET,默认生成VBS代码,可生成使用WMI获取管理信息或执行管理任务的代码,功能非常强大。

使用方法

WMI Code Creator中文版

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

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

WMI Code Creator中文版

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

WMI Code Creator中文版

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

WMI Code Creator中文版

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

WMI Code Creator中文版

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

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

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

WMI Code Creator中文版

如果通过常规手段在.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文件的引用,如下图:

WMI Code Creator中文版

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

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

///

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

///

///

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

{

///

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

/// 作者:周公

/// 日期:2008-1-14

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

///

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

{

///

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

/// 作者:周公

/// 时间:2008-1-14

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

///

public class GetSystemInfo

{

///

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

///

///

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;

}

///

/// 查询CPU编号

///

///

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;

}

///

/// 查询硬盘编号

///

///

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;

}

///

/// 主板编号

///

///

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;

}

///

/// 主板编号

///

///

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;

}

///

/// 主板编号

///

///

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;

}

///

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

///

///

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;

}

}

}

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

WMI Code Creator中文版

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

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

软件特色

1、WMI代码创建器工具可生成使用WMI获取管理信息或执行管理任务的代码。

2、您可以使用该工具学习如何使用WMI脚本和WMI .NET管理计算机。

3、该工具生成的代码可以在本地计算机,远程计算机或一组远程计算机上运行,​​具体取决于您在该工具上的目标计算机菜单中的选择。

4、您也可以直接从工具执行生成的代码。

5、该工具有助于避免编写使用WMI的代码的复杂性,并帮助开发人员和IT专业人员了解WMI可用于管理计算机的强大和实用性。

6、使用该工具您可以查询管理信息,例如操作系统的名称和版本,硬盘上的可用磁盘空间多少或服务的状态。

7、您还可以使用该工具从WMI类执行一个方法来执行管理任务。例如:您可以创建执行Win32_Process类的Create方法的代码,以创建新的进程(如记事本或其他可执行文件)。

8、该工具还允许您生成代码以使用WMI接收事件通知。例如,您可以选择在每次启动或停止进程或计算机关闭时接收事件。

9、该工具还允许您浏览本地计算机上可用的WMI名称空间和类,以查找其描述,属性,方法和限定符。

10、下载中还包含创建该工具的代码:该工具是使用WMI .NET创建的,该工具的代码可以帮助开发人员了解如何使用WMI .NET来创建应用程序和管理信息,请务必阅读下载中包含的最终用户许可协议。

11、支持查询BIOS的相关信息:可以在命名空间处选择rootCIMV2(这个是默认选择),然后在全部类处选择Win32_BIOS,这时就会列出Win32_BIOS类的所有属性,可以选择其中一个属性然后点击“查询属性值”。

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

更新日志

1、增加了可生成的代码类型

2、增加了一些新增代码的管理功能

3、解决了一些格式上的已知问题

4、修复了一些bug,优化了软件界面

5、优化了软件性能

  • 下载地址

点击报错软件无法下载或下载后无法使用,请点击报错,谢谢!