Apache Log4j2 远程代码执行漏洞分析+检测+防护

分析:

    Apache Log4j2是一款开源的Java日志框架,被广泛地应用在中间件、开发框架与Web应用中,用来记录日志信息。由于Apache Log4j2某些功能存在递归解析功能,未经身份验证的攻击者通过发送特别构造的数据请求包,可在目标服务器上执行任意代码。漏洞PoC已在网上公开,默认配置即可进行利用,该漏洞影响范围极广,建议相关用户尽快采取措施进行排查与防护。

    根据Iog4j的用途和复现的情况来看,攻击入口取决于Iog4j从线上业务的哪些地方取数据放入 logger.error,所以没有固定请求路径。另外由于线上web业务的任何数据都可能写入Iog4j,甚 至一些pre-auth的地方,比如注册、登录,所以这个漏洞的影响可能会被放大到未授权命令执行。  

检测:

 人工检测

1、相关用户可根据Java jar解压后是否存在org/apache/logging/log4j相关路径结构,判断是否使用了存在漏洞的组件,若存在相关Java程序包,则很可能存在该漏洞。

2、若程序使用Maven打包,查看项目的pom.xml文件中是否存在下图所示的相关字段,若版本号为小于2.15.0,则存在该漏洞。

3、若程序使用gradle打包,可查看build.gradle编译配置文件,若在dependencies部分存在org.apache.logging.log4j相关字段,且版本号为小于2.15.0,则存在该漏洞。

4、检测Ivy依赖版本是否低于 2.15.0

5、 检测SBT依赖版本是否低于 2.15.0

若没有使用上述工具,那么可以全局搜索log4j的相关jar包。 

受影响版本:

Apache Log4j 2.x <= 2.14.1

已知受影响应用及组件:

Apache Solr

Apache Flink

Apache Druid

srping-boot-strater-log4j2

更多组件可参考如下链接:

https://mvnrepository.com/artifact/org.apache.logging.log4j/log4j-core/usages?p=1

不受影响版本:

Apache log4j-2.15.0-rc1

防护:

1、升级

目前官方已发布测试版本修复该漏洞,受影响用户可先将Apache Log4j2所有相关应用到该版本,下载链接:https://github.com/apache/logging-log4j2/releases/tag/log4j-2.15.0-rc1
注:由于此版本非正式发行版,可能出现不稳定的情况,建议用户在备份数据后再进行升级。
升级供应链中已知受影响的应用及组件:Apache Solr、Apache Flink、Apache Druid、srping-boot-strater-log4j2

2、流量拦截

  • rulel $(jndi:ldap://
  • rule2 $(jndi:rmi:// 

以上流量特征可能出现在流量中的任何地方,也包括各种类型的请求(GET、POST等),所以需要对 整个请求流量做特征匹配。

以上正则对业务中的正常jndi流量无影响(恶意流量须包含${jndi:rmi${jndi:ldap,正常 业务jndi流量通常只包含rmi://ldap:// ),但是如果你的正常流量也包含上述特征请慎用。

3、临时防护

从官方给的信息和复现情况来看,利用手段是jndi注入无疑,jndi注入无非ldap、rmi,需要外连请 求Idap-server/exp-server,禁止外连能在一定程度上缓解,但是不能防御攻击者已控其他内部服务 器的情况。此外,JDK11.0.1、8u191、7u201、6u211或者更高版本默认是无法利用JNDI注入,JDK6u141、7u131、8u121或者更高版本无法利用RMI注入,网 上的一些bypas s方法也是依赖本地特定的lib(相当于找了新的gadgets),所以总结:

1、禁止使用Iog4j的服务器外连(日志服务器正常不需要外连)

     并在边界对dnslog相关域名访问进行检测。

     部分公共dnslog平台如下:

     ceye.io
     dnslog.link
     dnslog.cn
     dnslog.io
     tu4.org
     awvsscan119.autoverify.cn
     burpcollaborator.net
     s0x.cn

2、建议JDK使用高版本

3、添加jvm启动参数:-Dlog4j2.formatMsgNoLookups=true

  

4、在应用classpath下添加log4j2.component.properties配置文件,文件内容为:log4j2.formatMsgNoLookups=true

  

5、将系统环境变量 FORMAT_MESSAGES_PATTERN_DISABLE_LOOKUPS 设置为 true

  • 8
    点赞
  • 25
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论
### 回答1: Apache Log4j 2(简称Log4j2)是一个功能强大的日志记录工具,它能够帮助我们有效地记录日志信息,以便于追踪程序的运行情况和进行错误调试。Log4j2的使用非常简单,我们只需要在程序中引入相应的依赖库,然后在代码中配置相应的日志记录格式和输出位置即可。 Log4j2支持多种日志输出格式,包括控制台输出、文件输出、远程TCP输出等,我们可以通过简单的配置来选择相应的输出方式。此外,Log4j2还支持自定义的日志输出格式和布局,我们可以根据实际需求来扩展Log4j2的功能。 Log4j2还支持日志级别的设置,包括调试、信息、警告、错误和致命等5个级别,我们可以根据需要来设置相应的日志级别。此外,Log4j2还支持异步日志记录,可以在程序高并发的情况下保持高性能和低延迟。 总之,Apache Log4j2是一个非常优秀的日志记录工具,它提供了丰富的功能和灵活的配置方式,可以帮助我们快速、有效地记录日志信息,提高程序开发和调试的效率。 ### 回答2: apache log4j2是一种广泛使用的Java日志框架,可以帮助开发人员快速实现日志记录和管理。它与其他日志框架相比具有更高的性能和更丰富的功能。 使用apache log4j2,开发人员可以配置多种不同类型的日志记录器,可以使用多种不同的输出格式和目标设备,例如文件,控制台,甚至是网络。此外,apache log4j2 还支持使用各种不同的策略来推送日志信息,例如按照级别或文件大小进行轮换。 apache log4j2 还有一些其他的特性,例如日志过滤以及对多线程和分布式环境下应用程序的支持。它可以帮助开发人员更好地了解应用程序的运行状态,以及为调试和监视应用程序提供有用的数据。 总之,apache log4j2是一种非常有用的工具,可以帮助开发人员更轻松地管理和记录应用程序的日志信息,并且具有高性能和可扩展性的特点。对于日志记录是一个重要的应用程序,apache log4j2是一个必不可少的组件。 ### 回答3: Apache Log4j2 是一个 Java 的日志框架工具,它提供了高效和灵活的日志记录方式,支持多种日志级别和多种输出方式,并支持动态配置日志行为。 Log4j2 最大的优势是性能高和灵活性强。它使用异步日志来提高性能,同时还可以使用多种方式来输出日志,比如输出到控制台、文件、数据库等。它还可以自定义输出的格式和内容,这样我们就可以根据自己的需要来定制日志输出格式。 另外,Log4j2 还支持动态配置日志行为,这意味着我们可以在程序运行时动态的修改日志级别和输出方式,这样就可以实现更加灵活的日志输出机制。 总的来说,Apache Log4j2 是一个非常优秀的日志框架工具,它的性能、灵活性和可扩展性都非常高。使用它可以帮助我们更加有效地管理和记录程序运行过程中的信息,为我们开发和维护程序带来了很大的便利。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

306Safe

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值