WinRM 即 Windows Remote Management,是微软对于 WS-Management 远程管理协议的实现。
一、受控端配置 WinRM 服务
方式一:cmd 命令行(管理员)
- 启用 WinRM 远程服务:
winrm quickconfig
查看 WinRM 服务监听状态:
winrm e winrm/config/listener
1
2
3
4
5
6
7
8
9
10C:\Windows\system32>winrm e winrm/config/listener
Listener [Source="GPO"]
Address = *
Transport = HTTP
Port = 5985
Hostname
Enabled = true
URLPrefix = wsman
CertificateThumbprint
ListeningOn = 127.0.0.1, 169.254.52.7, xx.xx.xx.xx, ::1, fe80::3989:dd91:e6b3:6f41%15, fe80::fd01:a9fd:c410:3407%12允许使用 Basic 认证方式:
winrm set winrm/config/service/auth @{Basic="true"}
1
2
3
4
5
6
7
8winrm set winrm/config/service/auth @{Basic="true"}
Auth
Basic = true [Source="GPO"]
Kerberos = true
Negotiate = true
Certificate = false
CredSSP = false
CbtHardeningLevel = Relaxed允许 WinRM 使用非加密的连接:
winrm set winrm/config/service @{AllowUnencrypted="true"}
方式二:bat 脚本
1 | call winrm quickconfig -quiet |
方式三:组策略
定位到计算机配置 -> 策略 -> 管理模板 -> Windows 组件 -> Windows 远程管理(WinRM) -> WinRM 服务。
启用允许通过 WinRM 进行远程服务器管理、允许基本身份验证、允许未加密通信。
建议同时启用服务与防火墙策略:
计算机配置 -> 策略 -> Windows 设置 -> 安全设置 -> 系统服务 -> Windows Remote Management (WS-Management),启动模式为自动。
计算机配置 -> 策略 -> Windows 设置 -> 安全设置 -> 高级安全 Windows 防火墙 -> 高级安全 Windows 防火墙 - XXX -> 入站规则,开放 5985(HTTP)和 5986(HTTPS)端口。
二、Python 使用 pywinrm 连接 WinRM 服务
安装 pywinrm 库:pip install pywinrm
执行 cmd 命令:1
2
3
4
5import winrm
'xx.xx.xx.xx', auth=('Administrator', 'admin_password')) session = winrm.Session(
'ipconfig') cmd = session.run_cmd(
cmd.std_out
b'\r\nWindows IP Configuration\r\n\r\n\r\nEthernet adapter \xd2\xd4\xcc\xab\xcd\xf8:\r\n\r\n Connection-specific DNS Suffix . : example.com\r\n Link-local IPv6 Address . . . . . : fe80::3989:dd91:e6b3:6f41%15\r\n IPv4 Address. . . . . . . . . . . : xx.xx.xx.xx\r\n Subnet Mask . . . . . . . . . . . : 255.255.255.0\r\n Default Gateway . . . . . . . . . : 172.20.23.254\r\n\r\nEthernet adapter \xd2\xd4\xcc\xab\xcd\xf8 2:\r\n\r\n Media State . . . . . . . . . . . : Media disconnected\r\n Connection-specific DNS Suffix . : \r\n'
执行 Powershell 命令:1
2
3
4
5import winrm
'xx.xx.xx.xx', auth=('Administrator', 'admin_password')) session = winrm.Session(
'Get-Disk') ps = session.run_ps(
ps.std_out
b'\r\nNumber Friendly Name Serial Number HealthStatus OperationalStatus Total Size Partition \r\n Style \r\n------ ------------- ------------- ------------ ----------------- ---------- ----------\r\n0 ST500DM002... Z3TFS1S3 Healthy Online 465.76 GB MBR \r\n\r\n\r\n'