html 在weblogic 上编译报错,WebLogic EJBTaglibDescriptor XXE漏洞(CVE-2019-2888)分析

作者:Longofo@知道创宇404实验室

时间:2019年10月16日

原文链接:

这个漏洞和之前@Matthias Kaiser提交的几个XXE漏洞是类似的,而

EJBTaglibDescriptor应该是漏掉的一个,可以参考之前几个XXE的

。我和@Badcode师傅反编译了WebLogic所有的Jar包,根据之前几个XXE漏洞的特征进行了搜索匹配到了这个EJBTaglibDescriptor类,这个类在反序列化时也会进行XML解析。

环境

Windows 10

WebLogic 10.3.6.0.190716(安装了19年7月补丁)

Jdk160_29(WebLogic 自带的JDK)

漏洞分析

weblogic.jar!\weblogic\servlet\ejb2jsp\dd\EJBTaglibDescriptor.class这个类继承自

java\io\Externalizable

58c345c2a8fa470ab4ceacb8e299bb42.png

因此在序列化与反序列化时会自动调用子类重写的

writeExternal与

readExternal

看下

writeExternal的逻辑与

readExternal的逻辑,

8fe47680f28aef1fe260255dc1769284.png

readExternal中,使用

ObjectIutput.readUTF读取反序列化数据中的String数据,然后调用了load方法,

08d07acd3654c8b15e200b634f7c986f.png

在load方法中,使用

DocumentBuilder.parse解析了反序列化中传递的XML数据,因此这里是可能存在XXE漏洞的

writeExternal中,调用了本身的

toString方法,在其中又调用了自身的

toXML方法

b8f19023cb76174af8f4b69c00a4c82c.png

bbe3be4e11f563bbba3fafadfef83bae.png

toXML的作用应该是将

this.beans转换为对应的xml数据。看起来要构造payload稍微有点麻烦,但是序列化操作是攻击者可控制的,所以我们可以直接修改

writeExternal的逻辑来生成恶意的序列化数据:

9b6d69a458cb8d65158c8ed6f22adaac.png

漏洞复现

1、重写

EJBTaglibDescriptor中的

writeExternal函数,生成payload

7ef76649861626585dcdc7502e241cff.png

2、发送payload到服务器

6f75029dd908e60a025a2821778a83a5.png

在我们的HTTP服务器和FTP服务器接收到了my.dtd的请求与win.ini的数据

6e9e4e25a4d9a25ce50b736e393446c6.png

3、在打了7月份最新补丁的服务器上能看到报错信息

b71c38e915afae26919cb446caa64535.png

参考链接:

[1] 分析:

[2]

https://www.oracle.com/technetwork/security-advisory/cpuoct2019-5072832.html

如需转载请注明来源。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值
>