jackson学习之五:JsonInclude注解
欢迎访问我的GitHub
这里分类和汇总了欣宸的全部原创(含配套源码):https://github.com/zq2599/blog_demos
系列文章汇总
- jackson学习之一:基本信息
- jackson学习之二:jackson-core
- jackson学习之三:常用API操作
- jackson学习之四:WRAP_ROOT_VALUE(root对象)
- jackson学习之五:JsonInclude注解
- jackson学习之六:常用类注解
- jackson学习之七:常用Field注解
- jackson学习之八:常用方法注解
- jackson学习之九:springboot整合(配置文件)
- jackson学习之十(终篇):springboot整合(配置类)
本篇概览
- 本文是《jackson学习》系列第五篇,来熟悉一个常用的注解JsonInclude,该注解的仅在序列化操作时有用,用于控制方法、属性等是否应该被序列化;
- 之所以用单独的一篇来写JsonInclude注解,是因为该注解的值有多种,每种都有不同效果,最好的学习方法就是编码实战;
- 先对注解的所有取值做个简介:
ALWAYS // 默认策略,任何情况都执行序列化
NON_NULL // 非空
NON_ABSENT // null的不会序列化,但如果类型是AtomicReference,依然会被序列化
NON_EMPTY // null、集合数组等没有内容、空字符串等,都不会被序列化
NON_DEFAULT // 如果字段是默认值,就不会被序列化
CUSTOM // 此时要指定valueFilter属性,该属性对应一个类,用来自定义判断被JsonInclude修饰的字段是否序列化
USE_DEFAULTS // 当JsonInclude在类和属性上都有时,优先使用属性上的注解,此时如果在序列化的get方法上使用了JsonInclude,并设置为USE_DEFAULTS,就会使用类注解的设置
源码下载
- 如果您不想编码,可以在GitHub下载所有源码,地址和链接信息如下表所示(https://github.com/zq2599/blog_demos):
名称 | 链接 | 备注 |
---|---|---|
项目主页 | https://github.com/zq2599/blog_demos | 该项目在GitHub上的主页 |
git仓库地址(https) | https://github.com/zq2599/blog_demos.git | 该项目源码的仓库地址,https协议 |
git仓库地址(ssh) | git@github.com:zq2599/blog_demos.git | 该项目源码的仓库地址,ssh协议 |
这个git项目中有多个文件夹,本章的应用在jacksondemo文件夹下,如下图红框所示:
jacksondemo是父子结构的工程,本篇的代码在annotation子工程中,里面的jsoninclude这个package下,如下图:
- 接下来逐个学习这些属性的效果;
ALWAYS
ALWAYS表示全部序列化,如下图,null和空字符串都会序列化:
NON_NULL
NON_NULL好理解,就是值为null就不序列化:
NON_ABSENT
- NON_ABSENT略为复杂,当实例化的对象有Optional或AtomicReference类型的成员变量时,如果Optional引用的实例为空,用NON_ABSENT能使该字段不做序列化;
- Optional是java用来优雅处理空指针的一个特性,本文中不做过多说明,请您自行查阅相关文档;
- 要让Jackson支持Optional特性,必须做两件事,首先是在pom.xml中添加以下依赖:
<dependency><groupId>com.fasterxml.jackson.datatype</groupId><artifactId>jackson-datatype-jdk8</artifactId><version>2.11.0</version>
</dependency>
- 其次是代码中执行以下设置:
mapper.registerModule(new Jdk8Module());
咱们先看看设置成NON_NULL时jackson对Optional和AtomicReference的处理,下面的代码中,Optional和AtomicReference的引用都是空,但还是被序列化出来了:
代码不变,将NON_NULL改为NON_ABSENT试试,如下图,可见field2和field3都没有序列化了:
小结NON_ABSENT的效果:
a. 自身为null的字段不会被序列化;
b. Optional类型的字段,如果引用值为null,该字段不会被序列化;
c. AtomicReference类型的字段,如果引用值为null,该字段不会被序列化;
NON_EMPTY
NON_EMPTY好理解,以下情况都不会被序列化:
- null
- 空字符串
- 空集合
- 空数组
- Optional类型的,其引用为空
- AtomicReference类型的,其引用为空
- 演示代码和结果如下图,可见上述场景全部没有被序列化:
NON_DEFAULT
- 设置为NON_DEFAULT后,对保持默认值的字段不做序列化,如下图:
CUSTOM
- 相对其他类型,CUSTOM略为复杂,这个值要配合valueFilter属性一起使用;
- 如下所示,JsonInclude的value等于CUSTOM时,在序列化的时候会执行CustomFilter的equals方法,该方法的入参就是field0的值,如果equals方法返回true,field0就不会被序列化,如果equals方法返回false时field0才会被序列化
@JsonInclude(value = JsonInclude.Include.CUSTOM, valueFilter = CustomFilter.class)private String field0;
- 来看看CustomFilter类的代码,如下所示,只有equals方法,可见:null、非字符串、长度大于2这三种情况都返回true,也就是说这三种情况下都不会被序列化:
static class CustomFilter {@Overridepublic boolean equals(Object obj) {// null,或者不是字符串就返回true,意味着不被序列化if(null==obj || !(obj instanceof String)) {return true;}// 长度大于2就返回true,意味着不被序列化return ((String) obj).length() > 2;}}
- 下面贴出完整代码和结果,您就一目了然了:
- 再次强调:valueFilter的equals方法返回true,意味着该字段不会被序列化!!!
USE_DEFAULTS
USE_DEFAULTS的用法也有点绕,咱们通过对比的方法来学习;
- 代码如下所示,在类和成员变量上都有JsonInclude注解,序列化field0的时候,是哪个注解生效呢?:
@JsonInclude(JsonInclude.Include.NON_EMPTY)static class Test {@JsonInclude(JsonInclude.Include.NON_NULL)private List<String> field0;public List<String> getField0() { return field0; }public void setField0(List<String> field0) { this.field0 = field0; }}
把field0设置为空集合,运行代码试试,如果类上的注解生效,那么field0就不会被序列化(NON_EMPTY会过滤掉空集合),如果成员变量上的注解生效,field0就会被序列化(NON_NULL只过滤null,空集合不是null),执行结果如下图,可见是成员变量上的注解生效了:
接下来保持上述代码不变,仅在getField0方法上添加JsonInclude注释,值是USE_DEFAULTS,这样在序列化过程中,调用getField0方法时,就用类注解JsonInclude的值了,即NON_EMPTY:
@JsonInclude(JsonInclude.Include.USE_DEFAULTS)
public List<String> getField0() { return field0;
}
- 执行修改后的代码,如下图所示,此时用的成员变量field0上的注解就不生效了,而是类注解生效,导致空集合不被序列化:
小结USE_DEFAULTS的作用如下:
a. 类注解和成员变量注解同时存在时,以成员变量注解为准;
b. 如果对应的get方法也使用了JsonInclude注解,并且值是USE_DEFAULTS,此时以类注解为准;
至此,JsonInclude注解的学习和实战就完成了,希望本文能给您提供参考,助您熟练使用注解来指定更精确的序列化过滤策略;
欢迎关注公众号:程序员欣宸
微信搜索「程序员欣宸」,我是欣宸,期待与您一同畅游Java世界…
jackson学习之五:JsonInclude注解相关推荐
- jackson学习之五:JsonInclude注解,颠覆认知
ALWAYS ALWAYS表示全部序列化,如下图,null和空字符串都会序列化: NON_NULL NON_NULL好理解,就是值为null就不序列化: ![在这里插入图片描述](https://im ...
- jackson学习之一:基本信息
欢迎访问我的GitHub 这里分类和汇总了欣宸的全部原创(含配套源码):https://github.com/zq2599/blog_demos 系列文章汇总 jackson学习之一:基本信息 jac ...
- # Jackson 学习使用
Jackson 学习使用 文章目录 Jackson 学习使用 Jackson 优点 Jackson 的核心模块 引入 Jackson 依赖 多态类型的序列化及反序列化 @JsonTypeInfo Ob ...
- Jackson学习笔记
Java下常见的Json类库有Gson.JSON-lib和Jackson等,Jackson相对来说比较高效,在项目中主要使用Jackson进行JSON和Java对象转换,下面给出一些Jackson的J ...
- day 83 Vue学习之五DIY脚手架、webpack使用、vue-cli的使用、element-ui
Vue学习之五DIY脚手架.webpack使用.vue-cli的使用.element-ui 本节目录 一 vue获取原生DOM的方式 二 DIY脚手架 三 vue-cli脚手架的使用 四 webpac ...
- Hibernate学习之Hibernate注解总结
Hibernate学习之Hibernate注解总结http://www.bieryun.com/3269.html 一.类级别的注解 @Entity name:表的名字(可选)一般表名和类名相同 必须 ...
- java 注解 对象_Java基础-学习使用Annotation注解对象
Java基础-学习使用Annotation注解对象 注解(也被称为元数据)为我们在代码中添加信息提供了一种形式化的方法,使我们可以在稍后某 个时刻非常方便地使用这些数据 1-1:基本语法 Java S ...
- 【安卓学习之第三方库】 Aspect学习:AOP+注解
█ [安卓学习之第三方库] Aspect学习:AOP+注解 █ 相关文章: [安卓学习之第三方库]库的使用2-jar类库的使用(以dom4j为例)和升级(以极光推送为例) [安卓学习之第三方库] 消息 ...
- JUnit5学习之五:标签(Tag)和自定义注解
欢迎访问我的GitHub 这里分类和汇总了欣宸的全部原创(含配套源码):https://github.com/zq2599/blog_demos 关于<JUnit5学习>系列 <JU ...
最新文章
- Objective-C自动生成文档工具:appledoc
- 动态生成CheckBox(Winform程序)
- B树、B+树其实很简单,看不懂你找我
- 如何卸载安装有问题的devexpress组件?
- 湘财证券罗叶:数字化在金融领域的应用与实践,从“我觉得”到“用户觉得”...
- statusbar 尺寸 显示图标_StatusBar 图标展示流程 - 状态栏(StatusBar)镜头布局分析...- git完代码后的异常_169IT.COM...
- [CQOI2012] 局部极小值(状压DP + 容斥 + 搜索)
- 使用ajax完成python flask前端与后台数据的交互
- oracle服务名连接慢,数据库 – Oracle SID和服务名称;连接问题
- 嵌入式系统与人工智能
- 17. meta http-equiv 属性
- .NET Core微服务之基于Steeltoe使用Zipkin实现分布式追踪
- 股票历史数据-股票历史行情数据下载
- linux单引号作用,linux中单引号、双引号、反引号的作用
- pytorch 支持amd显卡吗_AMD平台上配置PyTorch+Apex开发环境
- okhttp使用总结
- 四、jQuery 中的事件和动画(嘎嘎详细)
- vue打包后华为手机自带浏览器访问空白
- matlab狗抓兔子,怎样训成年犬捉兔子-怎样训狗抓兔子
- 自定义控件---继承ViewGroup类方式(循序渐进之第3步效果----图片左右拖动+RadioGroup切换效果)
热门文章
- 计算机体系层次图中 虚拟机属于,第1章 计算机系统概述.ppt
- 计算机研究生报录比高的学校,报录比最高专业TOP10!就离谱!
- error: cannot lock ref 'refs/remotes/origin/test/pressure-test': 'refs/remotes/origin/test' exists;
- 大连工业大学艺术学院计算机考试,大连工业大学艺术与信息工程学院
- CSS3新增特性:选择器、盒子模型、其他属性
- Unity 获得Animator下某个动画片段的时长
- 2021 ACM杰出科学家揭榜:清华刘奕群、上科大虞晶怡等19位华人学者入选
- iphone有关旋转和自动调整大小
- iOS自定义相机实现拍照和连拍
- 电阻式压力传感器变送器技术选型及接线图解