使用WMI远程删除Windows 7网络打印机驱动程序

问题描述 投票:0回答:1

我需要一些帮助,使用远程计算机上具有管理员权限(高架帐户)的帐户的vbscript在Windows 7客户端计算机上远程删除网络打印机驱动程序。问题是我无法删除用户已连接的连接打印机。其他一切似乎都有效。下面是脚本的代码。

该脚本可以执行多项操作,但最终目标是物理删除打印机驱动程序。由于驱动程序文件正在使用,因此脚本的当前版本失败。该脚本包含避免删除特殊打印机的代码。它还会停止并启动打印后台处理程序。

intSleep        = 4000
strService      = " 'Spooler' "
strComputer         = "<remote computer name>"
Set fsobj       = CreateObject("Scripting.FileSystemObject") 'Calls the File System Object
Set objNetwork      = CreateObject("WScript.Network")
arrPrinters         = Array("PDF", "Adobe", "Remote", "Fax", "Microsoft", "Send To", "Generic")

Set objWMIService = GetObject("winmgmts:" _
    & "{impersonationLevel=impersonate}!\\" & strComputer & "\root\cimv2")

'   List drivers
Set colInstalledPrinters =  objWMIService.ExecQuery _
    ("Select * from Win32_PrinterDriver")

Set drivrutinCol  = CreateObject("Scripting.Dictionary")

For each objPrinter in colInstalledPrinters
'    Wscript.Echo "Configuration File: " & objPrinter.ConfigFile
'    Wscript.Echo "Data File: " & objPrinter.DataFile
'    Wscript.Echo "Description: " & objPrinter.Description
'    Wscript.Echo "Driver Path: " & objPrinter.DriverPath
'    Wscript.Echo "File Path: " & objPrinter.FilePath
'    Wscript.Echo "Help File: " & objPrinter.HelpFile
'    Wscript.Echo "INF Name: " & objPrinter.InfName
'    Wscript.Echo "Monitor Name: " & objPrinter.MonitorName
'    Wscript.Echo "Name: " & objPrinter.Name
'    Wscript.Echo "OEM Url: " & objPrinter.OEMUrl
'    Wscript.Echo "Supported Platform: " & objPrinter.SupportedPlatform
'    Wscript.Echo "Version: " & objPrinter.Version

    if InArray(objPrinter.Name, arrPrinters ) = False then
        Wscript.Echo "Name: " & objPrinter.Name
        drivrutinCol.Add    drivrutinCol.Count, Replace(objPrinter.ConfigFile, "C:", "\\" & strComputer & "\c$")
        drivrutinCol.Add    drivrutinCol.Count, Replace(objPrinter.DataFile, "C:", "\\" & strComputer & "\c$")
        drivrutinCol.Add    drivrutinCol.Count, Replace(objPrinter.DriverPath, "C:", "\\" & strComputer & "\c$")
    end if

Next

'   Remove network printers
Const NETWORK = 22
Set colInstalledPrinters = objWMIService.ExecQuery _
    ("Select * From Win32_Printer")

For Each objPrinter in colInstalledPrinters 
    If objPrinter.Attributes And NETWORK Then 

         ' The code never gets here for user connected network printers

    End If
Next

'   Stop Print Spooler Service
Set colListOfServices = objWMIService.ExecQuery _
        ("Select * from Win32_Service Where Name ="_
    & strService & " ")

For Each objService in colListOfServices
    objService.StopService()
    WSCript.Sleep intSleep
Next 

'   Delete drivers
for i = 0 to drivrutinCol.Count-1
    Wscript.Echo "Deleting driver: " & drivrutinCol.Item(i)
    fsobj.DeleteFile(drivrutinCol.Item(i))
Next

'   Start Print Spooler Service
For Each objService in colListOfServices
    WSCript.Sleep intSleep
    objService.StartService()
Next 

Function InArray(item,myarray)
  Dim i
  For i=0 To UBound(myarray) Step 1
    If InStr(lcase(item), lcase(myarray(i)))>0 Then
      InArray=True
      Exit Function
    End If
  Next
  InArray=False
End Function

代码的失败部分是“删除网络打印机” - 部分。该脚本不会列出用户在用户配置文件中连接的网络打印机,而只列出连接到计算机配置文件的本地打印机。

windows-7 printing vbscript wmi driver
1个回答
2
投票

要删除未登录用户的(网络)打印机连接,您需要将用户配置单元加载到注册表中并从Printers\Connections子项中删除相应的值:

Function qq(str) : qq = Chr(34) & str & Chr(34) : End Function

Set sh = CreateObject("WScript.Shell")

username = "..."
hive = "\\" & strComputer & "\C$\Users\" & username & "\ntuser.dat"

sh.Run "reg load HKU\temp " & qq(hive), 0, True
sh.RegDelete "HKEY_USERS\temp\Printers\Connections\server,printer"
sh.Run "reg unload HKU\temp", 0, True

您需要从网络共享加载配置单元,因为与其他子命令不同,loadunload不能与远程注册表一起使用。


要删除打印机驱动程序(从用户配置中删除打印机连接后),首先需要获取SeLoadDriverPrivilege,然后删除Win32_PrinterDriver类的相应实例(请参阅“备注”部分):

objWMIService.Security_.Privileges.AddAsString "SeLoadDriverPrivilege", True

qry = "SELECT * FROM Win32_PrinterDriver"
For Each driver In objWMIService.ExecQuery(qry)
  If driver.Name = "..." Then driver.Delete_
Next
© www.soinside.com 2019 - 2024. All rights reserved.