内容简介:Apache Log4j socket receiver deserialization vulnerability(CVE-2017-5645)
Log4j TCP socket server or UDP socket server在真正开发环境使用的不多,所以漏洞影响有限,利用思路跟之前的反序列化漏洞方式没有什么不同。
漏洞分析
根据漏洞描述,可知漏洞存在 TcpSocketServer类中。进入TcpSocketServer类的run方法,run方法中创建SocketHandler对象并调用了start()方法。 SocketHandler是TcpSocketServer的内部类,并且继承自Log4jThread,Log4jThread继承自Thread。 SocketHandle的start()方法调用会执行run方法,run方法主要逻辑是启动一个循环不断的接收序列化的日志流,问题就存在这里。
logEvents是一个泛型方法
public interface LogEventBridge<T extends InputStream> {
void logEvents(T var1, LogEventListener var2) throws IOException;
T wrapStream(InputStream var1) throws IOException;
}
实例化对化TcpSocketServer对象时传递的是ObjectInputStreamLogEventBridge实例
public static TcpSocketServer<ObjectInputStream> createSerializedSocketServer(int port) throws IOException {
LOGGER.entry(new Object[]{Integer.valueOf(port)});
TcpSocketServer<ObjectInputStream> socketServer = new TcpSocketServer(port, new ObjectInputStreamLogEventBridge());
return (TcpSocketServer)LOGGER.exit(socketServer);
}
跟进ObjectInputStreamLogEventBridge的logEvents方法,可以看到问题的原因了
漏洞测试
pom.xml配置
<!-- https://mvnrepository.com/artifact/org.apache.logging.log4j/log4j-core -->
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-core</artifactId>
<version>2.8.1</version>
</dependency>
public static void main(String argv[]) {
try {
TcpSocketServer socketServer = TcpSocketServer.createSerializedSocketServer(1234);
socketServer.run();
} catch (Exception e) {
}
}
最后给一个利用截图
修复方法
Log4j升级到2.8.2版本,已经加了白名单校验
漏洞检测
sudo -u admin lsof -X | grep log4j | grep jar | grep -v 2.8.2
参考
[1]: http://seclists.org/oss-sec/2017/q2/78
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
互联网创业核心技术:构建可伸缩的web应用
【美】Artur Ejsmont / 李智慧、何坤 / 电子工业出版社 / 2016-12 / 89
可伸缩架构技术是所有互联网技术中最重要,也是最引人入胜的技术。《互联网创业核心技术:构建可伸缩的web应用》针对互联网创业需求快速迭代,业务快速发展,短时间内用户、数据、访问量激增的特点,提纲挈领地描述了伸缩性架构的基本原理与设计原则,详细阐述了Web应用前端层、服务层、数据层的可伸缩架构,并花大量篇幅讲述了缓存技术和异步处理技术的可伸缩设计及其在Web系统中的具体应用。 《互联网创业核心技......一起来看看 《互联网创业核心技术:构建可伸缩的web应用》 这本书的介绍吧!
随机密码生成器
多种字符组合密码
HEX CMYK 转换工具
HEX CMYK 互转工具