基于@JsonSerialize和@JsonInclude注解使用方法
@jsonserialize和@jsoninclude注解
@jsonserialize
后端开发时返回给前端的数据格式有时可能并不符合。
举个例子,比如一张表中的时间,数据库中存储的是yyy-mm-dd hh:mm:ss 这样的形式,而前段需要的是精确到秒的格式,这是就会出现问题。此时可以利用@jsonserialize注解,改变返回给前端的json格式
@jsonserialize注解,主要用于数据转换,该注解作用在该属性的getter()方法上。
使用步骤
1. 指定一个格式化的类
里面写好规则
//jsonserializer<integer>:integer为要转换的类型 public class myserializerutils extends jsonserializer<integer> { @override public void serialize(integer status, jsongenerator jsongenerator, serializerprovider serializerprovider) throws ioexception, jsonprocessingexception { string statusstr = ""; switch (status) { case 0: statusstr = "暂存"; break; case 1: statusstr = "待上报"; break; case 2: statusstr = "待审核"; break; case 3: statusstr = "已审"; break; case 4: statusstr = "退回"; break; case -1: statusstr = "已删"; break; default: statusstr = "状态信息不符合"; } jsongenerator.writestring(statusstr); } }
或
//jsonserializer<date>:date为要转换的类型 public class date2longserializer extends jsonserializer<date> { @override public void serialize(date date, jsongenerator jsongenerator, serializerprovider serializerprovider) throws ioexception { jsongenerator.writenumber(date.gettime() / 1000); } }
2. 在实体类中在要转换的字段上加上该注解
@jsonserialize(using = myserializerutils.class) private int status;
或
//创建时间 @jsonserialize(using = date2longserializer.class) private date creattime; //更新时间 @jsonserialize(using = date2longserializer.class) private date updatetime;
@jsoninclude
返回前端的实体类中如果某个字段为空的话那么就不返回这个字段了
所以将@jsoninclude(include.non_null) 这个注解放在类头上就可以解决。 实体类与json互转的时候属性值为 null 的不参与序列化
jsonjsoninclude.include.always这个是默认策略,任何情况下都序列化该字段,和不写这个注解是一样的效果。
@data @jsoninclude(jsoninclude.include.non_null) public class orderdto { private string orderid; private string buyername; private string buyerphone; private string buyeraddress; private string buyeropenid; list<orderdetail> orderdetaillist;//null,不返回 }
如果多个类都需要不返回null,挨个加注释太麻烦了,可以全局设置,更改配置文件application.yml
spring: jackson: default-property-inclusion: non_null
如果list<orderdetail> orderdetaillist;需要返回一个空的list,但不能返回null,可以直接初始化
list<orderdetail> orderdetaillist = new arraylist<>();
同样若要返回空字符而不是null,初始化
private string msr = ""; private string data;
json @jsonserialize 弃用问题解决方案
@jsonserialize弃用spring boot中,返回json默认是包含空串的,如果我们不想让json返回null值,可以在bean上添加一些注解。
@jsoninclude(jsoninclude.include.non_empty)
后面的枚举值可以为
always, non_null, // 属性为null 不序列化,就是为null的字段不参加序列化 non_absent, // 属性为默认值不序列化 non_empty, // 属性为 空("") 或者为 null 都不序列化,则返回的json是没有这个字段的。这样对移动端会更省流量 non_default, custom, use_defaults;
调用
@jsoninclude(jsoninclude.include.non_empty) public class msgbean {}
ps:好多资料上说的@jsonserialize这个注解已经被弃用了~
以上为个人经验,希望能给大家一个参考,也希望大家多多支持。
上一篇: 正则表达式d元字符(相对于数字0-9)
下一篇: 深入浅析SpringBoot自动配置原理
推荐阅读
-
基于iOS pod最新的安装和使用方法(分享)
-
基于iOS pod最新的安装和使用方法(分享)
-
AOP之基于XML的声明式AspectJ和注解式AspectJ的实现
-
基于注解处理器开发自动生成getter和setter方法的插件
-
基于@JsonSerialize和@JsonInclude注解使用方法
-
基于@RequestBody注解只能注入对象和map的解决
-
使用前置通知进行访问控制:通过方法参数决定是否可以访问该方法,分别使用基于XML的声明式AspectJ和基于注解的声明式AspectJ来实现。
-
【Mybatis学习笔记(一)】分别基于Xml和注解的Mybatis环境搭建
-
Spring小白入门学习笔记(3)--AOP,AOP相关术语,基于XML和注解的AOP配置
-
基于@RequestBody注解只能注入对象和map的解决