Open PowerShell with administrator right to enable WinRM. Then type the following command, and press “Y” two times.
winrm quickconfig
data:image/s3,"s3://crabby-images/5ee9e/5ee9eb8f99a16fb8346a48de95a336c83fc14f58" alt=""
If your network connection type is Public, you will get an error below.
data:image/s3,"s3://crabby-images/74901/7490175f71876741362ff7a1876a0c8a53d072ca" alt=""
Go to Windows Firewall, and select “Public” on the Profiles setting to allow to connect via Public network.
data:image/s3,"s3://crabby-images/537d4/537d4f7729bd0485cd56e733d7de009cf6154bdc" alt=""
Test the WinRM configuration by running the following command.
winrm identify -r:http://localhost:5985 -auth:none
If the test is successful as in the screenshot below, your device is able to be managed via WMI.
data:image/s3,"s3://crabby-images/b87f4/b87f42be1307502419bafc4fa9605f05667c2651" alt=""
Check WinRM port is running.
data:image/s3,"s3://crabby-images/dc8ac/dc8acbb73fd422680a0c3389b5a7e94bc9de351b" alt=""
Remotely check WinRM port has listened on Windows machine.
Test-NetConnection WIN102022-01 -port 5985
data:image/s3,"s3://crabby-images/bd175/bd175b921d71b77bca5f7514b71e3df72839bb8d" alt=""
Enter WMI or WinRM credential for workgroup machine or Windows server.
PS C:\Windows\system32> $wmiuser, $wmisecret = (read-host 'Enter the WMIuser'), (Read-Host 'Enter the WMIsecret' -AsSecureString)
data:image/s3,"s3://crabby-images/0dcba/0dcba9da4dc39c788fadc1c5215c793c986f01bd" alt=""
A newadmin user is member of local Administrators on Windows workgroup machine or Windows server.
data:image/s3,"s3://crabby-images/747ca/747ca54e629ee01345d7d57e076458c7f614fe51" alt=""
Create wmi_cred_new variable for WMI or WinRM credential.
$wmi_cred_new = New-Object System.Management.Automation.PSCredential($wmiuser, $wmisecret)
data:image/s3,"s3://crabby-images/5a396/5a396803ca5b97a4278a6113caba17b4170ec056" alt=""
Check hostname and ipconfig on a remote host via WinRM.
Invoke-Command -ComputerName WIN102022-01 -Credential $wmi_cred_new -ScriptBlock {hostname; ipconfig}
data:image/s3,"s3://crabby-images/c0fee/c0fee90e8242cabfb27468243ef3d554b5435831" alt=""
Check current OS Windows Patch.
Invoke-Command -ComputerName WIN102022-01 -FilePath C:\Shared\Get-CurrentPatchInfo.ps1 -Credential $wmi_cred_new
data:image/s3,"s3://crabby-images/83c32/83c32687ff12898e4997c258d5c9f2d8342d36bd" alt=""
Get Lastreboot and uptime on Windows 10 workgroup machine.
Invoke-Command -ComputerName WIN102022-01 -Credential $wmi_cred_new -ScriptBlock {$OS1 = Get-WmiObject Win32_operatingsystem -Computer WIN102022-01 ; $LastReboot =($OS1.ConvertToDateTime($OS1.LastBootUpTime)) ; $LastReboot ; $Uptime = (Get-Date) -$OS1.ConvertToDateTime($OS1.LastBootUpTime) ; $Uptime = ([String]$Uptime.Days + " Days " + $Uptime.Hours + " Hours " + $Uptime.Minutes + " Minutes") ; $uptime}
data:image/s3,"s3://crabby-images/b6815/b6815bf9594024857cfe84449ee07d1a3cd9dc7f" alt=""