fastjson/jackson对getter,setter和constructor的区分

在复现完fastjson1.2.24-1.2.80和jackson的所有相关漏洞后,总结的一些规则

以下均指对json的反序列化过程

setter

fastjson调用setter:遍历所有方法,找出所有满足setter要求的方法,再根据传入的json去反射调用

jackson调用setter:直接对传入的json中的字段拼接上set,然后去取setter

其实二者一样,但是fastjson不能调用私有和受保护setter,而jackson可以

getter

fastjson调用getter:

1、没有setter方法,有getter方法。且getter满足:参数长度为0,返回类型是属于Collection 或其子类、Map 或其子类、AtomicBoolean、AtomicInteger、AtomicLong的一种

2、fastjson>=1.2.36 可用$ref调用getter

解析函数里有JSON.toJSON,还会调用getter(parseObject)

jackson调用getter:

1、没有setter,有getter方法。可以直接反序列化调用

2、jackson-databind&core&annotations>=2.13.3,通过POJONode调用getter

构造方法

fastjson调用构造方法:

  • 如果存在无参构造方法,则将其作为构造方法
  • 否则使用参数数量最多且排在最前面的构造方法。

jackson调用构造方法:

  • 按照顺序,如果有参构造的参数能对应上,直接调用
相关推荐
AutumnWind042016 分钟前
【Intelij IDEA使用手册】
java·ide·intellij-idea
就叫_这个吧1 小时前
Java注解、元注解、自定义注解定义及应用
java·开发语言·注解
Sam_Deep_Thinking2 小时前
聊聊Java中的of
java·开发语言·架构
网安小白的进阶之路2 小时前
B模块 安全通信网络 第二门课IPv6与WLAN 01
网络·安全
NE_STOP3 小时前
Docker--管理监控平台的应用
java
爱吃羊的老虎3 小时前
【JAVA】python转java:Spring Boot 入门
java·spring boot·python
Love_云宝儿3 小时前
GeoJSON简介
java·gis·地图·jts
摇滚侠4 小时前
JDBC 基础到高级一套通关!进阶篇 16-27
java
志栋智能4 小时前
安全超自动化:应对海量安全警报的唯一解
网络·安全·自动化
明志数科4 小时前
4D时序标注技术详解:让机器人理解连续动作的数据基础
java·算法·机器人