452

Apache Dubbo CVE-2019-17564 反序列化分析

 4 years ago
source link: https://y4er.com/post/apache-dubbo-cve-2019-17564/
Go to the source link to view the article. You can view the picture content, updated content and better typesetting reading experience. If the link is broken, please click the button below to view the snapshot at that time.

Apache Dubbo HTTP协议中的一个反序列化漏洞(CVE-2019-17564)

漏洞描述

Apache Dubbo支持多种协议,官方推荐使用Dubbo协议。Apache Dubbo HTTP协议中的一个反序列化漏洞(CVE-2019-17564),该漏洞的主要原因在于当Apache Dubbo启用HTTP协议之后,Apache Dubbo对消息体处理不当导致不安全反序列化,当项目包中存在可用的gadgets时即可导致远程代码执行。

影响范围

2.7.0 <= Apache Dubbo <= 2.7.4.1

2.6.0 <= Apache Dubbo <= 2.6.7

Apache Dubbo = 2.5.x

环境搭建

Dubbo 需要zookeeper,我采用虚拟机中的docker来搭建zookeeper环境。

docker run --rm --name zookeeper -p 2181:2181 zookeeper

B3i6rmQ.png!web

查看虚拟机是否开放2181端口

F32I3uB.png!web

下载官方的Dubbo http样例 https://github.com/apache/dubbo-samples/tree/master/java/dubbo-samples-http 导入idea

修改Dubbo为有反序列化漏洞的版本,我改为2.7.3

J3MVVfJ.png!web

因为Dubbo并没有可用的gadget,我们使用Commons-Collection4.4.0的gadget,所以在pom.xml中加入其依赖。

<dependency>
    <groupId>org.apache.commons</groupId>
    <artifactId>commons-collections4</artifactId>
    <version>4.0</version>
</dependency>

此时我们还要修改spring/http-provider.xml来指定zookeeper的IP

rIzmAnZ.png!web

改端口是因为8080端口和Burp的端口冲突了。修改完毕之后,启动HttpProvider。在控制台输出 dubbo service started 字样即表示启动成功。

漏洞复现

ysoserial生成payload

java -jar ysoserial.jar CommonsCollections4 calc > 1.ser

burp发包

u63ABrq.png!web

漏洞分析

断点 dubbo-2.7.3.jar!/org/apache/dubbo/remoting/http/servlet/DispatcherServlet.class:43

yuyMNji.png!web

跟进到 org.apache.dubbo.rpc.protocol.http.HttpProtocol.InternalHandler#handle

qe6fiam.png!web

获取了URI、请求方式和RPC调用的上下文,然后进入handleRequest()

nQbQBvq.png!web

handleRequest()将request请求对象传入一个参数的 readRemoteInvocation() ,然后将request和 request.getInputStream() 传入其重载方法两个参数的 readRemoteInvocation() ,然后创建了ois对象,ois对象中包含了post请求的数据,然后进入 doReadRemoteInvocation()

YNFvieZ.png!web

到达readObject(),整个过程ois对象没有过滤,而ois中又包含了post报文,导致反序列化漏洞,如果存在可用的gadget,会导致RCE。

修复建议

升级Apache Dubbo到最新版本

参考链接

文笔垃圾,措辞轻浮,内容浅显,操作生疏。不足之处欢迎大师傅们指点和纠正,感激不尽。


About Joyk


Aggregate valuable and interesting links.
Joyk means Joy of geeK