使用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對象進行設置,所有序列化的對象都將按改規(guī)則進行系列化 。
具體取值有:
//Include.Include.ALWAYS 默認
//Include.NON_DEFAULT 屬性為默認值不序列化
//Include.NON_EMPTY 屬性為 空(“”) 或者為 NULL 都不序列化
//Include.NON_NULL 屬性為NULL 不序列化
注意:只對VO起作用;對Map List不起作用
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
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 |
1
2
3
4
5
6
7
8
9
10
11
|
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原來經(jīng)過JACKSON轉換以后為{"name":"name","sex":null}
加入注解后,結果為{"name":"name"}
sex節(jié)點被去掉了
以上這篇jackson 實體轉json 為NULL或者為空不參加序列化(實例講解)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持服務器之家。
原文鏈接:http://blog.csdn.net/liuxiao723846/article/details/46043933