Esecuzione di query per istanze specifiche di una risorsa
La chiamata a Session.Enumerate include parametri facoltativi che restringeno l'enumerazione in una query. Poiché l'API di scripting WinRM e l'API C++ WinRM sono strettamente modellate sul protocollo WS-Management sottostante, i parametri usano la stessa terminologia per l'esecuzione di query del protocollo, ovvero il filtro e il dialetto di filtro.
È possibile usare i parametri di filtro e di dialetto di Session.Enumerate oppure è possibile costruire e fornire un oggetto ResourceLocator e il metodo AddSelector, ma non è possibile eseguire entrambe le operazioni.
Questa procedura esegue una query per le schede di rete con tcp/IP associato e abilitato. La query richiede tutte le istanze di Win32_NetworkAdapterConfiguration con la proprietà IpEnabled impostata su True. Ad eccezione dell'aggiunta del filtro e del dialetto, la query viene gestita come un'enumerazione semplice.
In questo esempio il nome della risorsa per la costante Resource è rappresentato da un asterisco "*" perché il nome della classe, Win32_NetworkAdapterConfiguration, è già menzionato nella stringa strFilter .
Per eseguire query per istanze specifiche di una risorsa
Per facilitare la lettura, definire gli URI come costanti.
Const RemoteComputer = "servername.domain.com" Const Resource = "http://schemas.microsoft.com/wbem/wsman/1/wmi/root/cimv2/*" Const Dialect = "http://schemas.microsoft.com/wbem/wsman/1/WQL"
Crea una sessione.
Set objWsman = CreateObject("Wsman.Automation") Set objSession = objWsman.CreateSession("https://" & RemoteComputer)
Costruire la stringa di filtro. Gestione remota Windows supporta WQL come dialetto del filtro.
strFilter = "SELECT * FROM Win32_NetworkAdapterConfiguration WHERE IpEnabled=TRUE"
Impostare le costanti di enumerazione necessarie nel parametro flags.
Tenere presente che se i flag includono le costanti di enumerazione WSManFlagHierarchyDeepBasePropsOnly o WSManFlagHierarchyShallow, il servizio WinRM restituisce il codice di errore ERROR_WSMAN_POLYMORPHISM_MODE_UNSUPPORTED.
Chiamare il metodo Session.Enumerate. Questa chiamata avvia un'enumerazione. Il metodo Session.Enumerate stabilisce un contesto di enumerazione del protocollo WS-Management, gestito nell'oggetto Enumerator .
Set objResultSet = objSession.Enumerate(Resource, strFilter, Dialect)
Chiamare il metodo Enumerator.ReadItem per ottenere l'elemento successivo dei risultati. Nel protocollo WS-Management corrisponde all'operazione pull. Utilizzare il metodo Enumerator.AtEndOfStream come controllo per sapere quando interrompere la lettura.
While Not objResultSet.AtEndOfStream DisplayOutput(objResultSet.ReadItem) Wend
Nell'esempio di codice VBScript seguente viene illustrato lo script completo.
Const RemoteComputer = "servername.domain.com"
Const Resource = "http://schemas.microsoft.com/wbem/wsman/1/wmi/root/cimv2/*"
Const Dialect = "http://schemas.microsoft.com/wbem/wsman/1/WQL"
Set objWsman = CreateObject("Wsman.Automation")
Set objSession = objWsman.CreateSession("https://" & RemoteComputer)
strFilter = "SELECT * FROM Win32_NetworkAdapterConfiguration WHERE IpEnabled=TRUE"
Set objResultSet = objSession.Enumerate(Resource, strFilter, Dialect)
While Not objResultSet.AtEndOfStream
DisplayOutput(objResultSet.ReadItem)
Wend
'****************************************************
' Displays WinRM XML message using built-in XSL
'****************************************************
Sub DisplayOutput(strWinRMXml)
Dim xmlFile, xslFile
Set xmlFile = CreateObject("MSXml2.DOMDocument.3.0")
Set xslFile = CreateObject("MSXml2.DOMDocument.3.0")
xmlFile.LoadXml(strWinRMXml)
xslFile.Load("WsmTxt.xsl")
Wscript.Echo xmlFile.TransformNode(xslFile)
End Sub
Argomenti correlati