当前位置:中国易下载软件教材中心文章中心编程语言VB语言 → 利用WMI获取系统信息

利用WMI获取系统信息

减小字体 增大字体 作者:佚名  来源:不详  发布时间:2007-8-21 1:01:58
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
喜欢这些内容嘛,请告诉你身边的朋友,易下载中心-QQ资源-itnetcn.com一起享受这份乐趣,本站内容来源互联网
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

利用WMI获取系统信息    WMI(Windows Management Instrumentation)技术是微软提供的Windows下的系统管理工具。通过该工具可以在本地或者管理客户端系统中几乎一切的信息。很多专业的网络管理工具都是基于WMI开发的。该工具在Win2000以及WinNT下是标准工具,在Win9X下是扩展安装选项。本文将介绍如何通过VB编程来访问WMI对象的编程46y海岸线网络安全资讯站
   首先来看一个简单的通过WMI获取系统信息的范例,这个范例通过WMI对象获得系统中运行的的进程:46y海岸线网络安全资讯站
Function Enum1() As String    Dim WMI46y海岸线网络安全资讯站
    Set WMI = GetObject("WinMgmts:")    Set objs = WMI.InstancesOf("Win32_Process") 46y海岸线网络安全资讯站
    For Each obj In objs        Enum1 = Enum1 + obj.Description + Chr(13) + Chr(10)    NextEnd Function 46y海岸线网络安全资讯站
    在上面的代码中,首先通过  GetObject("WinMgmts:")获得WMI对象,在WMI对象下有很多的子项,在这里我们通过WMI.InstancesOf("Win32_Process")获得系统中所有的进程列表子项。46y海岸线网络安全资讯站
    下面看一个完整的访问WMI对象的范例,这个范例获得计算机的信息。    建立一个新工程,在Form1中添加一个TextBox控件以及一个CommandButton控件,在CommandButton的Click事件中写入以下的代码46y海岸线网络安全资讯站
46y海岸线网络安全资讯站
Private Sub Command1_Click()    Dim s, System, item    Dim i As Integer46y海岸线网络安全资讯站
    Set System = GetObject("winmgmts:").InstancesOf("Win32_ComputerSystem")    For Each item In System        注释:List1.AddItem item.cputype        s = "Computer Info" & vbCrLf        s = s & "***********************" & vbCrLf        s = s & "计算机名称: " & item.name & vbCrLf46y海岸线网络安全资讯站
        s = s & "状态: " & item.Status & vbCrLf46y海岸线网络安全资讯站
        s = s & "类型: " & item.SystemType & vbCrLf46y海岸线网络安全资讯站
        s = s & "生产厂家: " & item.Manufacturer & vbCrLf46y海岸线网络安全资讯站
        s = s & "型号: " & item.Model & vbCrLf46y海岸线网络安全资讯站
        s = s & "内存: ~" & item.totalPhysicalMemory 1024000 & "mb" & vbCrLf46y海岸线网络安全资讯站
        s = s & "域: " & item.domain & vbCrLf46y海岸线网络安全资讯站
        注释:s = s & "工作组" & item.Workgroup & vbCrLf 注释:获得工作组和域的选项不能同时用 46y海岸线网络安全资讯站
        s = s & "当前用户: " & item.username & vbCrLf46y海岸线网络安全资讯站
        s = s & "启动状态" & item.BootupState & vbCrLf46y海岸线网络安全资讯站
        s = s & "该计算机属于" & item.PrimaryOwnerName & vbCrLf46y海岸线网络安全资讯站
        s = s & "系统类型" & item.CreationClassName & vbCrLf46y海岸线网络安全资讯站
        s = s & "计算机类类型" & item.Description & vbCrLf46y海岸线网络安全资讯站
46y海岸线网络安全资讯站
        For i = 0 To 1  注释:这里假设安装了两个系统 46y海岸线网络安全资讯站
            s = s & Chr(5) & "启动选项" & i & " :" & item.SystemStartupOptions(i) _ 46y海岸线网络安全资讯站
                & vbCrLf 46y海岸线网络安全资讯站
        Next i 46y海岸线网络安全资讯站
    Next46y海岸线网络安全资讯站
    Text1.Text = s 46y海岸线网络安全资讯站
End Sub 46y海岸线网络安全资讯站
    运行程序,点击Command1,在textBox中就可以显示计算机的信息。46y海岸线网络安全资讯站
    在上面的代码中,程序通过GetObject("winmgmts:")获得WMI对象,然后获得下面的46y海岸线网络安全资讯站
Win32_ComputerSystem子项并通过访问Win32_ComputerSystem对象中的分项获得系统中的信息。46y海岸线网络安全资讯站
需要说明的是,并不是所有的系统都支持WMI,在有些系统中无法显示生产厂家等信息。46y海岸线网络安全资讯站
46y海岸线网络安全资讯站
    现在的计算机以及网络组成十分复杂。例如系统硬件方面就有主板、硬盘、网卡... 。46y海岸线网络安全资讯站
软件方面有操作系统、系统中安装的软件、正在运行的进程等等。网络方面有域、工作组46y海岸线网络安全资讯站
等等。利用WMI可以访问上面的全部信息,但是如果向上面一样的利用分项来访问的话会很46y海岸线网络安全资讯站
麻烦。为此,WMI提供了一种类似SQL语句的查询语句,可以通过查询语句获得WMI对象下的子项。46y海岸线网络安全资讯站
46y海岸线网络安全资讯站
    下面是一个遍历系统中安装的网卡并返回网卡MAC地址的代码46y海岸线网络安全资讯站
Private Function MACAddress() As String46y海岸线网络安全资讯站
46y海岸线网络安全资讯站
   Set objs = GetObject("winmgmts:").ExecQuery( _46y海岸线网络安全资讯站
      "SELECT MACAddress " & _46y海岸线网络安全资讯站
      "FROM Win32_NetworkAdapter " & _46y海岸线网络安全资讯站
      "WHERE " & _46y海岸线网络安全资讯站
      "((MACAddress Is Not NULL) " & _46y海岸线网络安全资讯站
      "AND (Manufacturer <> " & _46y海岸线网络安全资讯站
      "注释:Microsoft注释:))")46y海岸线网络安全资讯站
   For Each obj In objs46y海岸线网络安全资讯站
      MACAddress = obj.MACAddress46y海岸线网络安全资讯站
      Exit For46y海岸线网络安全资讯站
   Next obj46y海岸线网络安全资讯站
End Function46y海岸线网络安全资讯站
    上面的代码获得WMI对象,然后运行ExecQuery执行一个WMI查询语句获得安装的网卡并返回46y海岸线网络安全资讯站
网卡的MAC地址。46y海岸线网络安全资讯站
    WMI还支持事件处理,让程序可以处理系统事件,例如程序运行、关闭,可移动驱动器的插入、46y海岸线网络安全资讯站
取出等。下面是一个可以对系统中运行程序进行监控的程序。46y海岸线网络安全资讯站
    首先建立一个新工程,然后点击菜单的 project | references 项,在references列表中选中46y海岸线网络安全资讯站
Microsoft WMI Scripting Library将WMI对象库加入工程中。然后在Form1中加入一个ListBox控件,46y海岸线网络安全资讯站
然后在Form1中加入以下代码46y海岸线网络安全资讯站
46y海岸线网络安全资讯站
Option Explicit 46y海岸线网络安全资讯站
46y海岸线网络安全资讯站
Dim Locator As SWbemLocator46y海岸线网络安全资讯站
Dim Services As SWbemServices46y海岸线网络安全资讯站
Dim WithEvents StatusSink As SWbemSink46y海岸线网络安全资讯站
Private Sub KillEvents()46y海岸线网络安全资讯站
    StatusSink.Cancel46y海岸线网络安全资讯站
    Set StatusSink = Nothing46y海岸线网络安全资讯站
End Sub46y海岸线网络安全资讯站
Private Sub Form_Load()46y海岸线网络安全资讯站
    Dim Query As String46y海岸线网络安全资讯站
    Set StatusSink = New SWbemSink46y海岸线网络安全资讯站
    Set Locator = CreateObject("WbemScripting.SWbemLocator")46y海岸线网络安全资讯站
    Set Services = Locator.ConnectServer()46y海岸线网络安全资讯站
    Query = "SELECT * FROM __InstanceCreationEvent "46y海岸线网络安全资讯站
    Query = Query + "WITHIN 1 "46y海岸线网络安全资讯站
    Query = Query + "WHERE TargetInstance ISA 注释:Win32_Process注释:" 46y海岸线网络安全资讯站
    Services.ExecNotificationQueryAsync StatusSink, Query46y海岸线网络安全资讯站
End Sub 46y海岸线网络安全资讯站
46y海岸线网络安全资讯站
Private Sub StatusSink_OnObjectReady(ByVal StatusEvent As SWbemObject, _46y海岸线网络安全资讯站
                                     ByVal EventContext As SWbemNamedValueSet) 46y海岸线网络安全资讯站
    Dim arr46y海岸线网络安全资讯站
    Dim strQue As String46y海岸线网络安全资讯站
    Dim i As Integer 46y海岸线网络安全资讯站
    List1.Clear46y海岸线网络安全资讯站
    arr = Split(StatusEvent.GetObjectText_, Chr(10))46y海岸线网络安全资讯站
    For i = LBound(arr) To UBound(arr)46y海岸线网络安全资讯站
        List1.AddItem arr(i)46y海岸线网络安全资讯站
    Next i46y海岸线网络安全资讯站
End Sub 46y海岸线网络安全资讯站
46y海岸线网络安全资讯站
Private Sub StatusSink_OnCompleted(ByVal HResult As WbemErrorEnum, _46y海岸线网络安全资讯站
                                   ByVal ErrorObject As SWbemObject, _46y海岸线网络安全资讯站
                                   ByVal EventContext As SWbemNamedValueSet) 46y海岸线网络安全资讯站
    If HResult <> wbemErrCallCancelled Then46y海岸线网络安全资讯站
        注释:错误处理46y海岸线网络安全资讯站
    End If46y海岸线网络安全资讯站
End Sub 46y海岸线网络安全资讯站
46y海岸线网络安全资讯站
    在上面的程序中定义了一个SWbemSink对象StatusSink,然后建立一个SWbemServices对象Server,46y海岸线网络安全资讯站
并将StatusSink连接到Server对象上。这样就可以通过StatusSink监控程序的运行。46y海岸线网络安全资讯站
    运行程序,然后任意运行一个程序,在Form1的ListBox中就可以列出运行的程序的信息。46y海岸线网络安全资讯站
    WMI应用最强大的一面是可以通过WEB页面来实现远程管理。下面我们来建立一个HTML页面,该页面46y海岸线网络安全资讯站
可以实现向上面的VB程序一样动态监控系统中运行的程序。监控系统中程序运行的HTML代码如下:46y海岸线网络安全资讯站
46y海岸线网络安全资讯站
<html>46y海岸线网络安全资讯站
<head>46y海岸线网络安全资讯站
<object ID="mysink" CLASSID= 46y海岸线网络安全资讯站
"CLSID:75718C9A-F029-11d1-A1AC-00C04FB6C223"></object>46y海岸线网络安全资讯站
</head>46y海岸线网络安全资讯站
<SCRIPT>46y海岸线网络安全资讯站
function window.onload() 46y海岸线网络安全资讯站
{46y海岸线网络安全资讯站
  var locator = new ActiveXObject ("WbemScripting.SWbemLocator"); 46y海岸线网络安全资讯站
  var service = locator.ConnectServer(); 46y海岸线网络安全资讯站
  szQuery = "SELECT * FROM __InstanceCreationEvent "; 46y海岸线网络安全资讯站
  szQuery += "WITHIN 1 "; 46y海岸线网络安全资讯站
  szQuery += "WHERE TargetInstance ISA 注释:Win32_Process注释:"; 46y海岸线网络安全资讯站
  service.ExecNotificationQueryAsync(mysink,szQuery);46y海岸线网络安全资讯站
}46y海岸线网络安全资讯站
</SCRIPT>46y海岸线网络安全资讯站
<script FOR="mysink" EVENT="OnObjectReady(obj, objAsyncContext)"> 46y海岸线网络安全资讯站
  document.all.info.innerHTML += obj.TargetInstance.Name + "<br>"; 46y海岸线网络安全资讯站
</script>46y海岸线网络安全资讯站
<body>46y海岸线网络安全资讯站
<span ID="info"></span> 46y海岸线网络安全资讯站
</body>46y海岸线网络安全资讯站
</html>46y海岸线网络安全资讯站
    保存代码为Htm后缀的页面文件。双击打开网页,然后运行一个程序,在网页上就可以列出46y海岸线网络安全资讯站
运行的程序的文件名。46y海岸线网络安全资讯站
46y海岸线网络安全资讯站
    以上简要的介绍了一下WMI的应用,实际上WMI对象的操作是十分复杂,功能也是很强大的,例如46y海岸线网络安全资讯站
你可以通过WMI在服务器上监控整个局域网上的计算机、向局域网上的计算机批量安装软件(例如杀46y海岸线网络安全资讯站
软件)。通过页面远程访问服务器,控件服务器运行程序,添加用户等。关于更多的WMI的应用,46y海岸线网络安全资讯站
读者可以访问MSDN上WMI开发的主页:46y海岸线网络安全资讯站
http://msdn.microsoft.com/library/default.asp?url=/library/en-us/wmisdk/wmistart_5kth.asp46y海岸线网络安全资讯站
获取更多信息。46y海岸线网络安全资讯站
46y海岸线网络安全资讯站
    以上程序在Win2000专业版下编写。46y海岸线网络安全资讯站
46y海岸线网络安全资讯站