百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 文章教程 > 正文

网络安全漏洞复现与分析

xsobi 2024-11-24 23:35 18 浏览

漏洞介绍

Weblogic的WLS Security组件对外提供webservice服务,其中使用了XMLDecoder来解析用户传入的XML数据,在解析的过程中出现反序列化漏洞,导致可执行任意命令。攻击者发送精心构造的xml数据甚至能通过反弹shell拿到权限。

影响版本

OracleWebLogic Server10.3.6.0.0
OracleWebLogic Server12.1.3.0.0
OracleWebLogic Server12.2.1.1.0
OracleWebLogic Server12.2.1.2.0

漏洞复现环境

攻击方:kali 2021

服务端:vulhub的weblogic的CVE-2017-10271环境

【一>所有资源关注我,私信回复“资料”获取<一】
1、200多本网络安全系列电子书(该有的都有了)
2、全套工具包(最全中文版,想用哪个用哪个)
3、100份src源码技术文档(项目学习不停,实践得真知)
4、网络安全基础入门、Linux、web安全、攻防方面的视频(2021最新版)
5、网络安全学习路线(告别不入流的学习)
6、ctf夺旗赛解析(题目解析实战操作)


漏洞复现

攻击方使用Burp发送反弹shell的payload:

成功得到shell:

POC

https://github.com/NingKn/CVE_EXP/blob/main/cve-2017-10271/cve-2017-10271.py

漏洞分析

CVE-2017-10271漏洞是WebLogic Server WLS组件的远程命令执行漏洞,触发漏洞url如下:

http://192.168.124.42:7001/wls-wsat/CoordinatorPortType 发送post数据包,通过构造SOAP(XML)格式的请求,在解析的过程中导致XMLDecoder反序列化漏洞。

  1. weblogic/wsee/jaxws/workcontext/WorkContextServerTube类的processRequest方法中,处理我们发送的POST数据包中的SOAP(XML)数据。var1即是传入的SOAP数据,我们idea配置好远程调试并且开启debug后,在processRequest方法中下断点:
  2. Burp通过post发送数据包后,idea停留在断点处,查看其中的var1变量既是我们发送的xml数据:
  3. 代码往下走,进入readHeaderOld方法,跟进前我们查看var3变量的信息:
  1. 跟进readHeaderOld方法,发现这里其实就是进行了一波转换,生成了WorkContextXmlInputAdapert var6对象,下图是该方法中的var4变量存放了的xml数据:
  2. Var6中的buf集合就是var4中的数据,及我们传输的xml:
  3. 跟进receive方法,var1实参是上面var6形参:
  4. 跟进var2的receiveRequest方法:
  1. 这里的var1就是上面的var1形参:
  1. 跟进receiveRequest方法:
  2. 跟进readEntry方法,var0存放了xml数据:
  1. 跟进var0的readUTF方法:

直接调用了xmlDecoder.readObject方法,产生漏洞。

总结:

XMLDecoder来解析用户传入的XML数据,在解析的过程中出现反序列化漏洞,导致可执行任意命令执行。

漏洞修复:

方法一:删除wls-wsat组件,然后重启weblogic

相关推荐

Python入门之Python的数据类型和常用操作符

一、Python的数据类型1、在Python中,int表示整型,bool表示布尔类型,float表示浮点类型,str表示字符串。计算机只认识二进制数,所有的编程语言都会转换成二进制语言给CPU按一定的...

金风科技:拟转让澳洲Moorabool风电项目股权及授出26%股权期权

【金风科技:拟转让澳洲Moorabool风电项目股权及授出26%股权期权】财联社12月20日电,金风科技公告,公司全资子公司金风国际Moorabool以1.77亿澳元的价格向Nebras电力转让其持有...

西门子SCL语言编程——PEEK/POKE指令

在SCL语言编程的时候,有两个特别有意思的指令,即读取存储地址和写入存储地址指令,梯形图中貌似没有的。标准地说是两类而不是两个,因为读和写都不止一个指令。先了解这两类指令的基本说明和用法,本篇后面的示...

【 PLC知识分享】PLC中常说的位元件、字元件的区别

#头条创作挑战赛#...

西门子TIA博途S7-1200/1500学习7间接寻址指令PEEK的使用

描述:...

C语言 | 关键字asm 、auto、bool、break 解析

asm插入一个汇编指令....

一文带你了解PLC的基本数据类型,很多电气师傅都不知道

...

什么是Python 之 ? 16 布尔值bool

Python的布尔值类型bool明确的一点是boolean值不是python专有的,其他编程语言javajavascriptphp等其实都有...

自动化PLC 基础 一个变量变成32个Bool 量 #plc编程

自动化PLCDINT数据类型变为BOOL量用。一次定义32个布尔量(BOOL)。前面给大家分享了罗可韦尔ABPLC数据类型的时候有讲到对于整数在ABPLC中最好定义为DINT的数据类型。今天给大家分享...

python数据类型-布尔类型bool(python中的布尔类型提供了哪两个值)

布尔类型是用于表示一种是与不是,对于不对等关系的类型布尔值只有两个:True和False布尔类型一般用于if判断和while循环中...

Python的布尔类型(bool)和布尔表达式

1.布尔类型(bool)Python的布尔类型是bool,表示真(True)或假(False)。它是整数的子类,True对应1,False对应0,但它们主要用于逻辑判断。值:True:代表...

记oracle日志挖掘实操&amp;查询归档不正常增长情况(一)

问题:最近几周经常手动删除归档日志,归档日志报空间不足(预留800G空间已用完),基于此查询归档日志情况(近期业务有所上涨)。-----------------------------此为回溯操作流程...

每天自动备份Oracle数据库(定时备份oracle数据库)

本文以CentOS7.6系统与Oracle11g为例,教你如何在Linux下设置每天自动备份Oracle数据库。一.先找到数据库的环境变量如果是在root账户下,须先登录到数据库所在账户suor...

避坑指南:KingbaseES Oracle模式中隐藏的&quot;双Date&quot;玄机

在数据库开发中,日期时间处理是高频操作场景。当您从Oracle迁移到国产数据库时,是否遇到过这样的困惑:...

ORACLE常见问题-100问(系列二)(oracle报错大全)

100.sql>startuppfile和ifile,spfile有什么区别?pfile就是Oracle传统的初始化参数文件,文本格式的;...