如何通过WMI获取BaseBoard的SerialNumber?

时间:2018-11-27 11:40:42

标签: wmi powerbuilder wql

有一个很好的示例可以在Powerbuilder中使用 WMI 来终止正在运行的进程。

可以使用相同的技术获取 BaseBoard SerialNumber 。我需要扩展相同的代码来处理WQL查询的返回值。

我要执行的WQL查询是:

SELECT Product, SerialNumber FROM Win32_BaseBoard

我可以执行上面的查询,但是在调用 ExecuteStatement ()函数之后,不知道如何将 SerialNumber 保存在变量中。

请查看链接以获取完整的PowerBuilder代码。 How to terminate a process if it has specific folder name in its path?

以下是从上面的链接中摘录的示例代码的一部分,以显示该功能。

wsh = CREATE OleObject
wsh.ConnectToNewObject("MSScriptControl.ScriptControl")
wsh.Language = "VBScript"
wsh.AddCode(TheCode)
TRY
    wsh.ExecuteStatement(FunctionName)
CATCH (RunTimeError Re01)
    MessageBox("Query Error", "Following code has some problems.~r~n~r~n" +                 TheCode, StopSign!)
END TRY
wsh.DisconnectObject()

DESTROY wsh

重要的函数调用      wsh.ExecuteStatement(FunctionName)

该函数调用后如何使用返回的 BaseBoard的序列号设置我的PowerBuilder局部变量?

1 个答案:

答案 0 :(得分:-1)

OLEObject ole_wsh
Any la_baseboard[]
string ls_message

 ole_wsh = CREATE OLEObject
 ole_wsh.ConnectToNewObject("MSScriptControl.ScriptControl")
 ole_wsh.Language = "vbscript"
 ole_wsh.AddCode('Function rtnBaseBoard()~r~n' &
 + 'DIM objBaseBoard(2)~r~n'  &
 + 'strComputer = "."~r~n'  &
 + 'Set objWMIService ='  &
 + '   GetObject("winmgmts:\\" & strComputer & "\root\cimv2")~r~n' &
 + 'Set colItems =' &
 + '    objWMIService.ExecQuery("SELECT Product, SerialNumber FROM Win32_BaseBoard")~r~n' &
 + 'For Each objItem in colItems~r~n' &
 + 'objBaseBoard(0) = objItem.Product~r~n' &
 + 'objBaseBoard(1) = objItem.SerialNumber~r~n' &
 + 'Next~r~n' &
 + 'rtnBaseBoard = objBaseBoard~r~n' &
 + 'End Function')
 la_baseboard[] = ole_wsh.Eval("rtnBaseBoard")
 ole_wsh.DisconnectObject()
 DESTROY ole_wsh

ls_message = "Product: " + string(la_baseboard[1]) + "~r~n" + &
+ "SerialNumber: " + string(la_baseboard[2]) + "~r~n" 
MessageBox("Win32 BaseBoard",ls_message)

使用WMI from Powerbuilder

查看更多示例