3d地图,芙蕖扮演者,安徽卫视现场直播
使用jackson进行序列化时,往往会遇到后台某个实体对象的属性为null,当序列化成json时对应的属性也为null;这样在某些前端组件上应用该json对象会报错。(例如:echarts)
下面总结了两种方法,解决了当属性为null时不参与序列化:
方法一:
1.实体上使用如下注解 @jsoninclude(include.non_null)
将该标记放在属性上,如果该属性为null则不参与序列化 ;如果放在类上边,那对这个类的全部属性起作用。
具体取值有:
//include.include.always 默认
//include.non_default 属性为默认值不序列化
//include.non_empty 属性为 空(“”) 或者为 null 都不序列化
//include.non_null 属性为null 不序列化
注:使用了该注解,那么在import时需要把一下两个类引入到源文件中
import com.fasterxml.jackson.annotation.jsoninclude;
import com.fasterxml.jackson.annotation.jsoninclude.include;
2.代码上使用如下方法:
objectmapper mapper = new objectmapper();
mapper.setserializationinclusion(include.non_null);
user user = new user(1,"",null);
string outjson = mapper.writevalueasstring(user);
system.out.println(outjson);
通过该方法对mapper对象进行设置,所有序列化的对象都将按改规则进行系列化 。
具体取值有:
//include.include.always 默认
//include.non_default 属性为默认值不序列化
//include.non_empty 属性为 空(“”) 或者为 null 都不序列化
//include.non_null 属性为null 不序列化
注意:只对vo起作用;对map list不起作用
objectmapper mapper = new objectmapper(); mapper.setserializationinclusion(include.non_null); map map = new hashmap(); map.put("a", null); map.put("b", "b"); string ret_val = mapper.writevalueasstring(map); system.err.println(ret_val); map m = mapper.readvalue(ret_val, map.class); system.err.println(m.get("a") + "|" + m.get("b")); 输出: {"b":"b","a":null} null|b
vo vo = new vo(); vo.seta(null); vo.setb("b"); string ret_val1 = mapper.writevalueasstring(vo); system.err.println(ret_val1); vo v = mapper.readvalue(ret_val1, vo.class); system.err.println(v.geta() + "|" + v.getb());<br> 输出 {"b":"b"} |b
方法二:
在实体类前,增加@jsonserialize(include=jsonserialize.inclusion.non_null) 注解
json原来经过jackson转换以后为{"name":"name","sex":null}
加入注解后,结果为{"name":"name"}
sex节点被去掉了
以上这篇jackson 实体转json 为null或者为空不参加序列化(实例讲解)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持移动技术网。
如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复
浅析我对 String、StringBuilder、StringBuffer 的理解
使用IDEA搭建SSM框架的详细教程(spring + springMVC +MyBatis)
Springboot整合freemarker 404问题解决方案
引入mybatis-plus报 Invalid bound statement错误问题的解决方法
网友评论