2022-卷王杯-happyFastjson

Posted bfengj

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了2022-卷王杯-happyFastjson相关的知识,希望对你有一定的参考价值。

2022-卷王杯-happyFastjson

前言

昨天看了fastjson,因为最近比赛的fastjson出现的有点多。卷王杯Y4出了道fastjson的题目,考点是比较基础的东西,学习一波。

分析

import java.io.ByteArrayOutputStream;
import java.io.InputStream;
import java.util.HashMap;
import java.util.Map;

public class FlagBean 
    private int count = 0;
    private boolean status = false;
    public String free;
    public String flab;

    public FlagBean() 
    

    public String getFree() 
        return this.free;
    

    public void setFree(String free) 
        this.free = free;
    

    public Map getMap() 
        --this.count;
        return null;
    
    public Map getFlag() 
        System.out.println("getFlag");
        ++this.count;
        if (this.count >= 2) 
            HashMap hashMap = new HashMap();
            hashMap.put("flag", "flag123");
            return hashMap;
         else 
            HashMap hashMap = new HashMap();
            hashMap.put("flag", "Hacker? hhd");
            return hashMap;
        
    

return StringUtils.check(poc) ? JSON.parse(poc).toString() : "Hacker? ";

主要就是fastjson反序列化触发2次getFlag()方法。

触发getter会想到$ref,但是被ban掉了,那么就想想办法,怎么在调用JSON.parse的时候触发getter。

首先是这个:

get开头的方法要求如下:

  • 方法名长度大于等于4
  • 非静态方法
  • 以get开头且第4个字母为大写
  • 无传入参数
  • 返回值类型继承自Collection Map AtomicBoolean AtomicInteger AtomicLong

只有满足这个要求的getter才会在JSON.parse的时候触发。

但是这才触发1次。

注意到后面return StringUtils.check(poc) ? JSON.parse(poc).toString() : "Hacker? ";还调用了一次,toString(),跟进去就发现是:

    public String toString() 
        return toJSONString();
    

估计大概率还能触发getter了,实际上也确实是这样,最后跟进下去,有2处可能触发getter:

第一处:

第二处:

我的payload:

poc="@type":"com.ctfshow.happyfjs.Beans.FlagBean","flag":"@type":"java.until.Map":"a"

可以触发3次getFlag,第一次是parse的时候,第二次就是JSON.toJSONString(entryKey),因为这时候的objectOrArray为false,第三次就是serializer.write(entryKey);

官方的payload只能触发2次,因为entryKey instanceof Map为true所以objectOrArray为true,这样第二次无法触发。

以上是关于2022-卷王杯-happyFastjson的主要内容,如果未能解决你的问题,请参考以下文章

2022-卷王杯-happyFastjson

尼恩Java面试宝典

“卷王”英伟达的真面目

公司来了个卷王,真让人奔溃

公司来了个卷王之王,让人崩溃

新入职了一个卷王,天天加班12点!张口闭口就是性能优化,太让人崩溃.........