当从 x64 进程请求 Win32_WinSAT 时,我得到正确的结果 (WinSATAssessmentState = 1),但当从 x86 执行时,我得到“结果不可用”(WinSATAssessmentState = 3)
x64 Powershell:
PS C:\Users\alive> gwmi Win32_WinSAT
__GENUS : 2
__CLASS : Win32_WinSAT
__SUPERCLASS :
__DYNASTY : Win32_WinSAT
__RELPATH : Win32_WinSAT.TimeTaken="MostRecentAssessment"
__PROPERTY_COUNT : 8
__DERIVATION : {}
__SERVER : COMPNAME
__NAMESPACE : root\cimv2
__PATH : \\COMPNAME\root\cimv2:Win32_WinSAT.TimeTaken="MostRecentAssessment"
CPUScore : 7,2
D3DScore : 6,3
DiskScore : 7,65
GraphicsScore : 4,6
MemoryScore : 5,9
TimeTaken : MostRecentAssessment
WinSATAssessmentState : 1
WinSPRLevel : 4,6
PSComputerName : COMPNAME
x86 Powershell
PS C:\Users\alive> gwmi Win32_WinSAT
__GENUS : 2
__CLASS : Win32_WinSAT
__SUPERCLASS :
__DYNASTY : Win32_WinSAT
__RELPATH : Win32_WinSAT.TimeTaken="MostRecentAssessment"
__PROPERTY_COUNT : 8
__DERIVATION : {}
__SERVER : COMPNAME
__NAMESPACE : root\cimv2
__PATH : \\COMPNAME\root\cimv2:Win32_WinSAT.TimeTaken="MostRecentAssessment"
CPUScore : 0
D3DScore : 0
DiskScore : 0
GraphicsScore : 0
MemoryScore : 0
TimeTaken : MostRecentAssessment
WinSATAssessmentState : 3
WinSPRLevel : 0
PSComputerName : COMPNAME
是否有任何标志或特殊方法能够从 x86 进程访问此信息?
Thanks.
你的问题属于在 64 位平台上请求 WMI 数据 http://msdn.microsoft.com/en-us/library/aa393067%28v=vs.85%29.aspx.
默认情况下,当存在两个版本的提供程序时,应用程序或脚本从相应的提供程序接收数据。 32 位提供程序将数据返回到 32 位应用程序,包括所有脚本,64 位提供程序将数据返回到 64 位编译的应用程序。但是,应用程序或脚本可以通过方法调用上的标志通知 WMI,从非默认提供程序(如果存在)请求数据。这__ProviderArchitecture and __所需架构字符串标志具有一组由 WMI 处理的值,但未在 SDK 标头或类型库文件中定义。这些值被放置在上下文参数中,以向 WMI 发出信号,表明它应该从非默认提供程序请求数据。
我不知道如何使用 PowerShell CmdLets 来做到这一点,但您可以使用 .NET Framework 中的“System.Management”类(COM 对象封装)。
# Setup the context information
$mContext = New-Object System.Management.ManagementNamedValueCollection
$mContext.Add( "__ProviderArchitecture", 64)
$mContext.Add( "__RequiredArchitecture", $true)
# Setup the Authrntification object
$ConOptions = New-Object System.Management.ConnectionOptions
#$ConOptions.Username = "computername\administrateur" # Should be used for remote access
#$ConOptions.Password = "toto"
$ConOptions.EnablePrivileges = $true
$ConOptions.Impersonation = "Impersonate"
$ConOptions.Authentication = "Default"
$ConOptions.Context = $mContext
# Setup the management scope (change with the computer name for remote access)
$mScope = New-Object System.Management.ManagementScope("\\localhost\root\cimV2", $ConOptions)
$mScope.Connect()
# Query
$queryString = "SELECT * From Win32_WinSAT"
$oQuery = New-Object System.Management.ObjectQuery ($queryString)
$oSearcher = New-Object System.Management.ManagementObjectSearcher ($mScope, $oQuery)
$oSearcher.Get();
我在 Windows 8 中从 32 位和 64 位 PowerShell 执行此脚本,两者都有效。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)