Fastjson实验(1.2.45-1.2.47)

Fastjson 1.2.45 到 1.2.47 版本的漏洞复现实验,我把整个实操过程和遇到的问题整理了一下,分享给同样在研究 Fastjson 漏洞的朋友,也当作自己的学习笔记。

一、Fastjson1.2.45版本

1.FastJson全版本Docker漏洞环境:https://github.com/lemono0/FastJsonParty

2.进入该版本的目录后docker compose up -d启动docker环境

3.打开后如图,我们登录并抓包,右键发送到重放器,发现是json格式

4.我们构造报错看看(删除最后一个花括号),确认是fastjson

**syntax error, position at X, name Y是最典型的fastjson特征**

5.fastjson版本探测,我们拼接payload(同样不加花括号),发现是1.2.45版本

6.接着我们探测java版本(不同版本的Java其内置的类库和可利用的链版本是完全不同的)

构造函数

{
    "@type": "java.lang.Class",
    "val": "一个不存在的类名,例如com.example.nonexistent"
}

Java 版本

响应特征

<font style="color:rgb(0, 0, 0);"><= 8u121</font>

HTTP 状态码 200,无异常或错误信息包含 <font style="color:rgb(0, 0, 0);">jsonClass</font>

<font style="color:rgb(0, 0, 0);">8u121+ ~ 11</font>

HTTP 状态码 500,错误信息包含 <font style="color:rgb(0, 0, 0);">getJsonClass</font>/ <font style="color:rgb(0, 0, 0);">setJsonClass</font>等关键字

<font style="color:rgb(0, 0, 0);">>= 11</font>

HTTP 状态码 500,错误信息不包含 <font style="color:rgb(0, 0, 0);">jsonClass</font>,但包含 <font style="color:rgb(0, 0, 0);">getModule</font><font style="color:rgb(0, 0, 0);">module</font>等关键字

7.确定了是高版本JDK,所以我们使用JNDIBypass.jar 工具。

我们先打开kali开始监听9001端口

发现反弹不到shell

8.换个方式,我们把JNDIBypass.jar工具放到公网上,执行命令,在请求包中构造请求,连接JNDIBypass.jar给的链接

9.成功连接

二、Fastjson1.2.47版本

1.启docker环境,进入页面

2.抓包分析,确认使用了fastjson

3.确定版本

4.判断出网

{
  "@type":"java.net.Inet4Address",
  "val":"yomiom.dnslog.cn"
}

5.尝试注入冰蟹马

6.连接成功

三、Fastjson1.2.47版本存在WAF

1.启docker环境,进入页面

2.抓包分析,确认使用了fastjson

3.确定版本,发现hacker!这个字眼,说明存在WAF

4.我们编码尝试一下(尝试使用unicode或者hex编码来处理payload,因为fastjson默认解析这两种编码。)使用unicode编码发现绕过成功

5.判断出网,还是编码绕过

6.那么我们还是注入冰蟹码,这里拼接payload的时候我们使用yakit(编码方便)

7.我们使用冰蝎连接,连接成功

这次实验下来,发现 Fastjson 1.2.45 和 1.2.47 版本的漏洞利用思路大体一致,遇到 WAF 时,利用 Fastjson 对编码的原生支持做关键字绕过,是很直接有效的方法。

大家有问题可以在评论区交流,欢迎大家点赞收藏~

(提示:测试一定要在合法授权的环境下进行,禁止未经允许测试他人网站,遵守法律和道德底线!)

### 回答1: 要下载Fastjson-1.2.47,您可以按照以下步骤进行: 1. 打开您喜欢使用的浏览器,例如谷歌浏览器,火狐浏览器等。 2. 在搜索栏中输入"Fastjson-1.2.47下载",点击搜索按钮。 3. 在搜索结果中,您可能会找到许多网站提供的Fastjson-1.2.47的下载链接。选择一个您信任的官方网站,或者选择一些广受好评的下载站点。 4. 点击您选择的下载链接,进入Fastjson-1.2.47的下载页面。 5. 在下载页面上,您可能会看到一些说明和选项。根据您的需求,选择适当的选项,例如下载版本(如果有多个版本提供),下载平台等。 6. 点击"下载"按钮,开始下载Fastjson-1.2.47。 7. 下载完成后,找到下载的文件。通常情况下,它会保存在您的计算机的默认下载文件夹中。 8. 双击下载的文件,运行安装程序。按照提示完成安装过程。 9. 安装完成后,您现在可以使用Fastjson-1.2.47进行开发和其他操作了。 请注意,在任何时候下载软件时,要确保从可信的来源下载软件,并在安装之前使用杀毒软件进行扫描,以确保安全性。 ### 回答2fastjson-1.2.47是一个用于Java编程语言的JSON(JavaScript Object Notation)解析器和生成器。它可以将Java对象转换为JSON格式的字符串,并将JSON字符串转换为对应的Java对象。要下载fastjson-1.2.47,您可以按照以下步骤进行操作: 1. 打开一个网页浏览器,进入fastjson的官方下载页面。 2. 在页面上找到fastjson-1.2.47的下载链接,并单击它。 3. 选择您希望将fastjson-1.2.47下载到的位置。这可以是您的计算机上的任何文件夹或目录。 4. 单击“下载”按钮开始下载fastjson-1.2.47。 5. 等待下载完成。下载速度取决于您的互联网连接速度和下载文件的大小。 6. 下载完成后,在您选择的目标位置找到下载的fastjson-1.2.47文件。 7. 可能需要解压缩fastjson-1.2.47文件(如果下载的是压缩包)。您可以使用解压缩软件(如WinRAR或7-Zip)来执行此操作。 8. 现在,您可以在您的Java项目中使用fastjson-1.2.47了。将fastjson的JAR文件添加到您的项目构建路径中,并根据fastjson的文档或示例代码来使用它。 通过按照上述步骤下载并使用fastjson-1.2.47,您将能够在您的Java项目中轻松地解析和生成JSON数据。 ### 回答3: 要下载fastjson-1.2.47,可以按照以下步骤进行操作: 1. 打开浏览器,进入fastjson的官方网站。 2. 在网站的顶部导航栏或页面中找到“下载”选项,并点击进入下载页面。 3. 在下载页面中,找到fastjson-1.2.47版本的下载链接,一般会以类似于“Download JSON-1.2.47”的形式呈现。 4. 点击下载链接,浏览器将开始下载fastjson-1.2.47的压缩包(通常为zip或tar.gz格式)。 5. 下载完成后,解压缩该压缩包到指定的目录中。 6. 接下来,可以根据需要将fastjson-1.2.47导入到项目中。可以使用IDE,如Eclipse或IntelliJ IDEA,在项目中创建一个新的库,并将解压后的fastjson文件夹添加到该库中;或者直接将fastjson的jar文件添加到项目的classpath中。 7. 确保正确导入fastjson后,即可开始使用fastjson-1.2.47进行JSON数据的处理和操作。 总结:要下载fastjson-1.2.47,首先访问fastjson的官方网站,找到下载页面并下载该版本的压缩包。然后解压缩,并将其导入到项目中,即可开始使用fastjson-1.2.47
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值