基于@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这个注解已经被弃用了~
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
基于springboot i18n国际化后台多种语言设置的方式
这篇文章主要介绍了基于springboot i18n国际化后台多种语言设置的方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2021-06-06Java工具之ja-netfilter 2022.1 配置教程
这篇文章主要介绍了Java工具之ja-netfilter 2022.1 配置教程,本防火墙基于javaagent,所以目前只有基于java的程序能够使用,需要的朋友可以参考下2022-04-04Mybatis事务如何跟Spring结合(数据库事务特性和Spring事务管理源码)
MyBatis与Spring的事务结合主要是通过Spring的事务管理和MyBatis的数据库操作来实现的,在本文中,我们将从数据库事务特性和Spring事务管理源码两个角度来分析MyBatis事务如何与Spring结合到一起的原理,感兴趣的朋友一起看看吧2024-01-01
最新评论