重庆分公司,新征程启航

为企业提供网站建设、域名注册、服务器等服务

jackson实体转json为NULL或者为空不参加序列化(实例讲解)

使用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());
输出 {"b":"b"} |b

方法二:

在实体类前,增加@JsonSerialize(include=JsonSerialize.Inclusion.NON_NULL) 注解

JSON原来经过JACKSON转换以后为{"name":"name","sex":null}

加入注解后,结果为{"name":"name"}

sex节点被去掉了

以上这篇jackson 实体转json 为NULL或者为空不参加序列化(实例讲解)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持创新互联。


新闻名称:jackson实体转json为NULL或者为空不参加序列化(实例讲解)
分享链接:http://cqcxhl.com/article/pccoho.html

其他资讯

在线咨询
服务热线
服务热线:028-86922220
TOP