【脚本】python中wmi介绍和使用

发布时间:2019-08-30 08:33:10编辑:auto阅读(1763)

    一:WMI基础知识
    ===================================================================
    WMI 最初于1998年作为一个附加组件与 Windows NT 4.0 Service Pack 4 一起发行,是内置在Windows 2000、 Windows XP和Windows Server 2003 系列操作系统中核心的管理支持技术。基于由 Distributed Management Task Force (DMTF) 所监督的业界标准,WMI是一种规范和基础结构,通过它可以访问、配置、管理和监视几乎所有的Windows资源。大多用户习惯于使用众多的图形化管理工 具来管理Windows资源,在WMI之前这些工具都是通过 Win32应用程序编程接口(Application ProgrammingInterfaces,API)来访问和管理Windows资源的。只要你熟悉系统编程你就知道API有多么重要。但是大多数脚本 语言都不能直接调用Win32 API,WMI的出现使得系统管理员可以通过一种简便的方法即利用常见的脚本语言实现常用的系统管理任务。
    利用WMI需要和脚本如WSH和VBScript结合起来,可以实现的功能大家可以看微软的MSDN文档。
    在编写我们自己的脚本之前,我们需要对WMI的体系结构有个基本的了解。如图一:(1.gif)

    在WMI 体系结构中我们最需要关心的就是WMI提供程序,WMI提供程序在WMI和托管资源之间扮演着中间方的角色。提供程序代表使用者应用程序和脚本从WMI托 管资源请求信息,并发送指令到WMI托管资源。下面是我们利用WMI编程经常要用到的WMI内置提供程序清单,以供编程参考。


    1.Active Directory提供程序
    链接库文件:dsprov.dll
    命名空间:root\directory\ldap
    作用:将Active Directory 对象映射到 WMI。

    2.事件日志提供程序
    链接库文件:ntevt.dll
    命名空间:root\cimv2
    作用:管理 Windows 事件日志,例如,读取、备份、清除、复制、删除、监视、重命名、压缩、解压缩和更改事件日志设置。

    3.注册表提供程序
    链接库文件:stdprov.dll
    命名空间:root\default
    作用:读取、写入、枚举、监视、创建、删除注册表项和值。

    4.Win32 提供程序
    链接库文件:cimwin32.dll
    命名空间:root\cimv2
    作用:提供关于计算机、磁盘、外围设备、文件、文件夹、文件系统、网络组件、操作系统、打印机、进程、安全性、服务、共享、SAM 用户及组,以及更多资源的信息。

    5.Windows 安装程序提供程序
    链接库文件:msiprov.dll
    命名空间:root\cimv2
    作用:提供对已安装软件信息的访问。

    从 上面可以看出在WMI中类(即内置提供程序)被分组到命名空间中,命名空间可以看成是一个组。比如,命名空间 root\cimv2 包括大部分表示通常与计算机和操作系统相关联的资源的类。在使用类的时候要说明类所在的命名空间。类由属性和方法构成。这是可视化编程中的两个重要的概 念。属性描述的是对象的状态,方法是对象可以执行的操作。

    接着看python 中的WMI使用

    是Tim Golden's 的WMI.PY,使用起来非常简单.下面的例子是摘自它自身提供的example

    import wmi

    c = wmi.WMI ()
    for s in c.Win32_Service ():
    if s.State == 'Stopped':
      print s.Caption, s.State
    打印WIN的服务名称和状态.其中服务是在停止状态下才打印.

    List all running processes

    import wmi
    c = wmi.WMI ()
    for process in c.Win32_Process ():
    print process.ProcessId, process.Name
    简单吧,几天语句就把进程列出来了,提权什么都不用,比用delphi方便多了,嘿嘿,不过就是速度慢了点。

    Reboot a remote machine

    import wmi
    c = wmi.WMI (computer="other_machine", privileges=["RemoteShutdown"])
    os = c.Win32_OperatingSystem (Primary=1)[0]
    os.Reboot ()


    Show the IP and MAC addresses for IP-enabled network interfaces

    import wmi
    c = wmi.WMI ()
    for interface in c.Win32_NetworkAdapterConfiguration (IPEnabled=1):
    print interface.Description, interface.MACAddress
    for ip_address in interface.IPAddress:
      print ip_address
    print


    List registry keys

    import _winreg
    import wmi
    r = wmi.Registry ()
    result, names = r.EnumKey (hDefKey=_winreg.HKEY_LOCAL_MACHINE, sSubKeyName="Software")
    for key in names:
    print key
    操作注册表.

    越用越爽啊,简单易用,真不愧是pythonic啊。当然还有很多其他的example,自己看咯.

    wmi python
    http://tgolden.sc.sabren.com/python/wmi.html
    wim cookbook
    http://tgolden.sc.sabren.com/python/wmi_cookbook.html

关键字