我目前的代码如下:
define ( 'CPU_NAME', 'remote_server' );
$obj = new COM ( 'winmgmts:{impersonationLevel=impersonate}//' . CPU_NAME . '/root/cimv2' );
if ( is_object ( $obj ) ){
$process = $obj->execquery ( "SELECT * FROM Win32_Process" );
}
我将把remote_server的登录凭据放在哪里? 我看到它需要用户名和密码,但我不确定如何实现它。
任何帮助都将不胜感激。
答案 0 :(得分:13)
<?php
$obj = new COM ( 'winmgmts://localhost/root/CIMV2' );
$fso = new COM ( "Scripting.FileSystemObject" );
$wmi_computersystem = $obj->ExecQuery("Select * from Win32_ComputerSystem");
$wmi_bios = $obj->ExecQuery("Select * from Win32_BIOS");
$processor = $obj->ExecQuery("Select * from Win32_Processor");
$PhysicalMemory = $obj->ExecQuery("Select * from Win32_PhysicalMemory");
$BaseBoard = $obj->ExecQuery("Select * from Win32_BaseBoard");
$LogicalDisk = $obj->ExecQuery("Select * from Win32_LogicalDisk");
foreach ( $wmi_computersystem as $wmi_call )
{
$model = $wmi_call->Model;
}
foreach ( $wmi_bios as $wmi_call )
{
$serial = $wmi_call->SerialNumber;
$bios_version = $wmi_call->SMBIOSBIOSVersion;
}
foreach ( $processor as $wmi_processor )
{
$idprocessor = $wmi_processor->ProcessorId;
$Architecture = $wmi_processor->Architecture;
$Name = $wmi_processor->Name;
$Version = $wmi_processor->Version;
}
foreach ( $PhysicalMemory as $wmi_PhysicalMemory )
{
$Capacity = $wmi_PhysicalMemory->Capacity;
$PartNumber = $wmi_PhysicalMemory->PartNumber;
$Name = $wmi_PhysicalMemory->Name;
}
foreach ( $BaseBoard as $wmi_BaseBoard )
{
$SerialNumber = $wmi_BaseBoard->SerialNumber;
}
foreach ( $LogicalDisk as $wmi_LogicalDisk )
{
$SerialNumberDisk = $wmi_LogicalDisk->VolumeSerialNumber;
$FileSystem = $wmi_LogicalDisk->FileSystem;
}
echo "Bios version : ".$bios_version."<br/>
Serial number of bios : ".$serial."<br/>
Hardware Model : ".$model."<br/>
ID-Processor : ".$idprocessor."<br/>
Architecture-Processor : ".$Architecture."<br/>
Name-Processor : ".$Name."<br/>
Version-Processor : ".$Version."<br/>
<hr>
<hr>
PhysicalMemory
<hr>
<hr>
Capacity : ".$Capacity."<br/>
Name : ".$Name."<br/>
<hr>
<hr>
carte mere
<hr>
<hr>
SerialNumber : ".$SerialNumber."<br/>
<hr>
<hr>
disk
<hr>
<hr>
SerialNumber : ".$SerialNumberDisk."<br/>
FileSystem : ".$FileSystem."<br>
";
?>
答案 1 :(得分:2)
适用于全球管理员
define("NAMECOMP", 'COMP1'); // COMP1 - name or ip of local or remote computer
$WMI= new COM ( 'winmgmts:{impersonationLevel=impersonate}//'. NAMECOMP.'/root/cimv2' );
使用登录名和密码
$objLocator = new COM("WbemScripting.SWbemLocator");
$objService = $objLocator->ConnectServer(
'ComputerName', //name/ip remote/local comp
"root\cimv2",
'login', //login remote/local comp
'password', //password remote/local comp
"MS_409",
"ntlmdomain: YourDomain" //domain remote/local comp
);
$CountCore=0;
foreach ($WMI->instancesof ( 'Win32_Processor' ) as $proc ) {
++$CountCore;
}
echo 'Count Core = ' . $CountCore;
添加速度和套接字处理器的信息
$CountCore=0;
foreach ($WMI->instancesof ( 'Win32_Processor' ) as $Processor) {
++$CountCore;
$Speed=$Processor->CurrentClockSpeed;
$Socket=$Processor->SocketDesignation;
}
echo 'count core = '.$CountCore;
echo 'speed = ' . $Speed. 'Mhz';
echo 'socket = '.$Socket;
获取其他信息简单 - 只需替换instanceof('Win32_Processor')
的类if ((($_GET['Reboot']==1) OR ($_GET['Shutdown']==1))) {
define("NAMECOMP", 'COMP1');
$WMI= new COM('winmgmts:{impersonationLevel=impersonate,(Shutdown)}//'. NAMECOMP.'/root/cimv2');
foreach($WMI->instancesof('Win32_OperatingSystem') as $mp) {
if ($_GET['Reboot']==1) {
$mp->Reboot;
}
if ($_GET['Shutdown']==1) {
$mp->Shutdown;
}
}
<强>链接:强>
答案 2 :(得分:1)
<?php
$strComputer = "YOURREMOTEHOST";
$objSWbemLocator = new COM ("WbemScripting.SWbemLocator");
$objSWbemServices = $objSWbemLocator->ConnectServer($strComputer, "root\cimv2", "DOMAIN\USER", "Password");
$objSWbemServices->Security_->ImpersonationLevel = 3;
$obj = $objSWbemServices;
$fso = new COM ( "Scripting.FileSystemObject" );
//... insert your code here
//... insert your code here
?>
答案 3 :(得分:1)
我知道这个帖子不是最新的但maby这个信息可以帮助某人。 如果您尝试在远程计算机上读取或写入Registy密钥或已安装的Software类,则需要在查询运行时传递架构。你可以使用这样的东西。
function Connect($server = "RemotePC",$namespace = "root/CIMV2",$impersonate = 3,$Architecture = 64,$userid = null,$password = null){
try {
$wbemnvs = new COM("WbemScripting.SWbemNamedValueSet");
$wbemnvs->add("__ProviderArchitecture", $Architecture);
$wbemnvs->add("__RequiredArchitecture", true);
$wmiLocator = new COM("WbemScripting.SWbemLocator");
$this->wmiNameSpace = $wmiLocator->ConnectServer($server, $namespace, $userid, $password,null,null,128,$wbemnvs);
if($this->wmiNameSpace){
$this->ConnectedServer = $server;
}else{ return false; }
if($impersonate){
// mehr infos: http://msdn.microsoft.com/en-us/library/aa393618%28v=vs.85%29.aspx
$this->wmiNameSpace->Security_->ImpersonationLevel = $impersonate;
}
return true;
}
catch(Exception $e){
$this->wmiNameSpace = NULL;
return false;
}
}
查看我的wmi.class.php:http://scbbb.blogspot.de/2014/02/wmi-via-php.html