问题描述
所以我试图编写一个脚本,从网络上的计算机收集系统信息,然后将收集到的信息写入我的 C:\ 驱动器中的 HTML 文件。这是我目前所拥有的。
Invoke-Command -computername WIN-I9EKPIP774N -credential Administrator -ScriptBlock {
$OS= (Get-WmiObject -class Win32_OperatingSystem).Caption;
$PK= powershell "(Get-WmiObject -query ‘select * from SoftwareLicensingService’).OA3xOriginalProductKey";
$MN= (Get-WmiObject -Class:Win32_ComputerSystem).Manufacturer;
$SN= Get-WmiObject win32_bios | Select SerialNumber;
$cpu= Get-WMIObject win32_Processor | select name;
$RAM= (systeminfo | Select-String 'Total Physical Memory:').ToString().Split(':')[1].Trim();
$GPU= Get-WmiObject win32_VideoController|select videoProcessor; Write-host "GPU: "
$Result= $GPU,$OS,$PK,$SN,$cpu,$RAM
$Result|out-file C:/SYSINFO.HTML -computername DESKTOP-TA132FJ}
该命令可以很好地收集远程计算机上的信息,但我无法将其发回以将信息写入我的本地文件。我分别通过 IP 和主机名将这些机器添加到了受信任的主机,但仍然无法让它连接回我的本地机器并写入文件。任何帮助将不胜感激。
解决方法
目前你有这样的事情:
Invoke-Command -computername blah -ScriptBlock { (do stuff) | out-file targetfile.txt }
因为 out-file
在脚本块中,所以它在远程计算机上执行。最简单的解决方法是将它移动到脚本块之外,所以它更像是:
Invoke-Command -computername blah -ScriptBlock { (do stuff) } | out-file targetfile.txt
这样,输出将通过本地计算机上的 out-file
进行管道传输,您无需尝试反向计算权限。
你可以把它想象成你放在脚本块旁边的一切,都会在远程计算机上发生,任何外来者都会在你的本地计算机上运行。
考虑到这一点,如果您在 SB 中写入文件,它将被写入远程磁盘。 PS 的另一个特点是事物(在本例中为 Invoke-Command)几乎总是返回事物,因此如果删除 $Result
之后的所有内容,包括 |
,将返回数组 $Result
.
因此您可以将其放入变量,然后将其写入文件。
$Computer = "WIN-I9EKPIP774N"
$stuff = @{ win32_operatingsystem = "Version"
SoftwareLicensingService = "OA3xOriginalProductKey"
win32_ComputerSystem = "Manufacturer"
win32_bios = "SerialNumber"
win32_Processor = "Name"
Win32_PhysicalMemory = "Capacity"
win32_VideoController = "videoProcessor"
}
$SysInfo = [pscustomobject]::new()
$stuff.Keys | foreach { $SysInfo | Add-Member -MemberType NoteProperty -Name $_ -Value ( Get-CimInstance -ClassName $_ -ComputerName $Computer )."$( $stuff.$_ )" }
$SysInfo | Out-File C:\SYSINFO.HTML
编辑
我意识到我在代码建议中犯了一些错误,因此重写并修改了它以使其更易于处理。
$stuff
包含您要从中获取信息的类以及该类的属性。
如果有多个存储卡,RAM 将是每个存储卡的容量列表。
事实证明,如果您创建一个变量并将 invoke 命令存储在该变量中,然后将该变量通过管道传输到输出文件,您就会得到结果。此外,我没有使用计算机名称,而是通过 IP 地址将系统添加到受信任的主机文件中。生成的代码如下所示。
$OVERALL= Invoke-Command -computername 172.16.50.50 -credential Administrator -ScriptBlock {
$OS= (Get-WmiObject -class Win32_OperatingSystem).Caption;
$PK= powershell "(Get-WmiObject -query ‘select * from SoftwareLicensingService’).OA3xOriginalProductKey";
$MN= (Get-WmiObject -Class:Win32_ComputerSystem).Manufacturer;
$SN= Get-WmiObject win32_bios | Select SerialNumber;
$CPU= Get-WMIObject win32_Processor | select name;
$RAM= (systeminfo | Select-String 'Total Physical Memory:').ToString().Split(':')[1].Trim();
$GPU= Get-WmiObject win32_VideoController|select videoProcessor;
$Result= $GPU,$OS,$PK,$SN,$CPU,$RAM;
$Result};
$OVERALL| Out-file C:\SYSINFO.HTML
这样就成功地从localhost向远程机器发送了sys信息的请求,并将远程主机的sys信息写入到了localhost上的html文件中。很酷的学习体验!