weblogic basedoman 加载两个项目_【更新】Weblogic远程代码执行漏洞CVE20202551

CVE-2020-2551远程代码执行漏洞是Oracle官方2020年1月关键补丁更新的重要漏洞。该漏洞可以绕过Oracle官方在2019年10月份发布的安全补丁,攻击者可以通过IIOP协议远程访问Weblogic Server服务器上的远程接口,传入精心构造的数据,在目标服务器上执行任意代码。近期深信服千里目安全实验室成功复现此漏洞,并发布解决方案。

漏洞名称:Weblogic远程代码执行漏洞CVE-2020-2551

威胁等级:高危

影响范围: 

WebLogic Server 10.3.6.0.0

WebLogic Server 12.1.3.0.0

WebLogic Server 12.2.1.3.0

WebLogic Server 12.2.1.4.0

漏洞类型:远程代码执行

利用难度:简单

漏洞分析

1 WebLogic组件介绍

WebLogic是美国Oracle公司出品的一个application server,确切的说是一个基于JAVAEE架构的中间件,WebLogic是用于开发、集成、部署和管理大型分布式Web应用、网络应用和数据库应用的Java应用服务器。

将Java的动态功能和Java Enterprise标准的安全性引入大型网络应用的开发、集成、部署和管理之中。WebLogic是商业市场上主要的Java(J2EE)应用服务器软件(application server)之一,是世界上第一个成功商业化的J2EE应用服务器,具有可扩展性,快速开发,灵活,可靠性等优势。

2 漏洞描述

该漏洞可以绕过Oracle官方在2019年10月份发布的最新安全补丁。IIOP协议以Java接口的形式对远程对象进行访问,默认启用。攻击者可以通过IIOP协议远程访问Weblogic Server服务器上的远程接口,传入精心构造的数据,在目标服务器上执行任意代码。CVSS评分9.8。

3 漏洞分析

以weblogic10.3.6.0作为漏洞环境进行分析,我们通过IIOP协议向服务器发送反序列化数据后,可以在weblogic.iiop.MuxableSocketIIOP.dispatch的传入参数中看到我们传入的IIOP数据。

d41a97754d7a1e94ba33f9057fb90107.png

之后我们会在weblogic.rmi.internal.wls.WLSExecuteRequest类中的run()方法调用handleRequest()方法

29c0af41ff37c3eb45a0019fae7cc9c7.png

在handleRequest()方法中,存在runAS()方法,可以通过其中的invoke()方法调用weblogic.rmi.cluster.ClusterableServerRef类中的invoke()方法。

391b3de553056d6c36264f05f9ecf6b1.png

通过此方法可以调用weblogic.corba.idl.CorbaServerRef类中的invoke()方法。

5d77f848472a3b07a73c2b4e511c8979.png

首先代码会判断链接是否存在,如果不存在,则直接抛出异常。之后会判断var4.getmethod()是否为空,如果为空,则调用delegate._invoke()方法。

6877825996b51e92e1e380f7f56ddc85.png

由于var4的类型是bind_any(),且objectMethods中不要包括此类型,所以进入delegate._invoke()方法中。

d93e137f92ed1871f9cdcb7141cbfeca.png

74a146897dc11d5326cd7751c1d2a6c7.png

由于bind_any对应的值为0,所以后续会进入case 0的代码分支中。

074cf3caed0c5f184e3d717c32889621.png

调用read_any()方法最终会进入weblogic.corba.idl.AnyImpl类中的read_value_internal()方法,并调用read_value()方法进行反序列化操作

54c8a16f6a0061185d73c3b98b4c016c.png

在weblogic.iiop.IIOPInputStream.read_value()方法中,通过反射机制获取IIOP数据中传入的类的实例。

6f49784d348fa28ce9bf76135d23c65f.png

0c402d72eb467826304c42d8a8a83921.png

之后会调用weblogic.corba.utils.ValueHandlerImpl.readValueData()方法进行内容读取。

432c154994c67922066bacf8b50ab746.png

6347c2661f6fefbfb84181775121217b.png

通过this.readObjectMethod.invoke()方法进入com.bea.core.repackaged.springframework.transaction.jta.JtaTransactionManager类中。

d14619c55a8ae692595fdb6504caf9ea.png

进入initUserTransactionAndTransactionManager()方法中,通过jndi寻址,加载远程服务器上的恶意文件,执行任意代码。

27efbe4a08f575d770faf87c6298e7b4.png

至此,攻击流程结束。

4 漏洞复现

搭建weblogic 10.3.6.0漏洞环境,构造恶意的反序列化数据,通过IIOP发送到目标服务器,当目标服务器解析反序列化数据,会触发恶意代码执行,效果如图:

a1354463cf8a083008f90f3030453924.png

影响范围

目前受影响的Weblogic版本:

WebLogic Server 10.3.6.0.0

WebLogic Server 12.1.3.0.0

WebLogic Server 12.2.1.3.0

WebLogic Server 12.2.1.4.0

解决方案

1修复建议

1.官方已经针对此漏洞发布补丁,请受影响的用户参考以下链接安装补丁更新:https://www.oracle.com/security-alerts/cpujan2020.html

2.可通过关闭IIOP协议对此漏洞进行临时防御。操作如下:

在Weblogic控制台中,选择“服务”->”AdminServer”->”协议”,取消“启用IIOP”的勾选。并重启Weblogic项目,使配置生效。

c945b8b0703bd0472517aa88d00ba9a4.png

2 深信服解决方案

深信服下一代防火墙】可轻松防御此漏洞, 建议部署深信服下一代防火墙的用户更新至最新的安全防护规则,可轻松抵御此高危风险。

深信服云盾】已第一时间从云端自动更新防护规则,云盾用户无需操作,即可轻松、快速防御此高危风险。

深信服安全感知平台】可检测利用该漏洞的攻击,实时告警,并可联动【深信服下一代防火墙等产品】实现对攻击者ip的封堵。

深信服安全运营服务】深信服云端安全专家提供7*24小时持续的安全运营服务。在漏洞爆发之初,云端安全专家即对客户的网络环境进行漏洞扫描,保障第一时间检查客户的主机是否存在此漏洞。对存在漏洞的用户,检查并更新了客户防护设备的策略,确保客户防护设备可以防御此漏洞风险。

深信服安全云眼】在漏洞爆发之初,已完成检测更新,对所有用户网站探测,保障用户安全。不清楚自身业务是否存在漏洞的用户,可注册信服云眼账号,获取30天免费安全体验。

注册地址:http://saas.sangfor.com.cn

深信服云镜】在漏洞爆发第一时间即完成检测能力的发布,部署了云镜的用户可以通过升级来快速检测网络中是否受该高危风险影响,避免被攻击者利用。离线使用云镜的用户需要下载离线更新包来获得漏洞检测能力,可以连接云端升级的用户可自动获得漏洞检测能力。

时间轴

2020/1/15

Oracle发布2020年1月关键补丁更新中修复了CVE-2020-2551远程代码执行漏洞。  

2020/1/15

深信服千里目安全实验室对此漏洞发布预警文章。

2020/3/13

深信服千里目安全实验室复现此漏洞,并发布解决方案。


文章推荐:

1.Weblogic远程代码执行漏洞(CVE-2020-2546、CVE-2020-2551)

2.微软SMBv3 Client/Server远程代码执行漏洞安全风险通告(CVE-2020-0796)


点击阅读原文关注并登录深信服智安全Wiki平台,及时查询漏洞的产品解决方案,我们持续更新~

a2ddff0b9f15349c3559c091f188e07b.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值