FastJson、Jackson、Gson进行Java对象转换Json的细节处理

转 https://blog.csdn.net/moneyshi/article/details/51830329

Java对象转换Json的细节处理

前言

Java对象在转json的时候,如果对象里面有属性值为null的话,那么在json序列化的时候要不要序列出来呢?对比以下json转换方式

一、fastJson

1、fastJson在转换java对象为json的时候,默认是不序列化null值对应的key的

也就是说当对象里面的属性为空的时候,在转换成json时,不序列化那些为null值的属性
 
具体案例如下:
AutoPartsSearchRequest 有以下属性:
 
  1. public static void main(String[] args) {
  2. AutoPartsSearchRequest request = new AutoPartsSearchRequest();
  3. request.setKeywords("123");
  4. request.setSortingField("234242");
  5. String str = JSONObject.toJSONString(request);//fastjson默认转换是不序列化null值对应的key的
  6. System.out.println(str);
  7. }

输出结果:{"keywords":"123","sortingField":"234242"}  , 没有序列化那些值为null的属性
 

2、但是如果想把null对应的key序列化出来呢? 

那就要仔细看看fastjson转换java对象为json的时候的入参了:也就是这个方法:
 
JSONObject.toJSONString(Object object, SerializerFeature... features)

Fastjson的SerializerFeature序列化属性:


 
  1. QuoteFieldNames———-输出key时是否使用双引号,默认为true
  2. WriteMapNullValue——–是否输出值为null的字段,默认为false
  3. WriteNullNumberAsZero—-数值字段如果为null,输出为0,而非null
  4. WriteNullListAsEmpty—–List字段如果为null,输出为[],而非null
  5. WriteNullStringAsEmpty—字符类型字段如果为null,输出为”“,而非null
  6. WriteNullBooleanAsFalse–Boolean字段如果为null,输出为false,而非null
 
结合上面,SerializerFeature... features是个数组,那么我们可以传入我们想要的参数,比如想序列化null,案例如下:
  1. public static void main(String[] args) {
  2. AutoPartsSearchRequest request = new AutoPartsSearchRequest();
  3. request.setKeywords("123");
  4. request.setSortingField("234242");
  5. String str = JSONObject.toJSONString(request, SerializerFeature.WriteMapNullValue);
  6. System.out.println(str);
  7. }

输出结果如下:
 

 

3、想字符类型字段如果为null,转换输出为”“,而非null ,需要多加一个参数:WriteNullStringAsEmpty, 案例如下:

 
  1. public static void main(String[] args) {
  2. AutoPartsSearchRequest request = new AutoPartsSearchRequest();
  3. request.setKeywords("123");
  4. request.setSortingField("234242");
  5. String str = JSONObject.toJSONString(request, SerializerFeature.WriteMapNullValue,
  6. SerializerFeature.WriteNullStringAsEmpty);
  7. System.out.println(str);
  8. }

输出结果如下:
 
 
 
 
 
 

二、Jackson

 

1、jackson默认是序列化null对应的key的,也就是说不管你对象属性有没有值,在转换json的时候都会被序列化出来

  1. public static void main(String[] args) throws JsonGenerationException, JsonMappingException, IOException {
  2. AutoPartsSearchRequest request = new AutoPartsSearchRequest();
  3. request.setKeywords("123");
  4. request.setSortingField("234242");
  5. ObjectMapper mapper = new ObjectMapper();
  6. String str = mapper.writeValueAsString(request);
  7. System.out.println(str);
  8. //输出结果(此处就不格式化了):{"sortingField":"234242","partsClassifyId":null,"partsSubClassifyId":null,"sortingDirection":null:......
  9. }

 

2、同理,想要不序列化null也是可以的,具体如下:

  1. 1.实体上
  2.  
  3. @JsonInclude(Include.NON_NULL)
  4.  
  5. //将该标记放在属性上,如果该属性为NULL则不参与序列化
  6. //如果放在类上边,那对这个类的全部属性起作用
  7. //Include.Include.ALWAYS 默认
  8. //Include.NON_DEFAULT 属性为默认值不序列化
  9. //Include.NON_EMPTY 属性为 空(“”) 或者为 NULL 都不序列化
  10. //Include.NON_NULL 属性为NULL 不序列化
  11.  
  12.  
  13. 2.代码上
  14. ObjectMapper mapper = new ObjectMapper();
  15.  
  16. mapper.setSerializationInclusion(Include.NON_NULL);
  17.  
  18. //通过该方法对mapper对象进行设置,所有序列化的对象都将按改规则进行系列化
  19. //Include.Include.ALWAYS 默认
  20. //Include.NON_DEFAULT 属性为默认值不序列化
  21. //Include.NON_EMPTY 属性为 空(“”) 或者为 NULL 都不序列化
  22. //Include.NON_NULL 属性为NULL 不序列化


注意:只对VO起作用,Map List不起作用,另外jackson还能过滤掉你设置的属性,具体的就各位自己去研究源码了

或者参照:jackson详解

 
 

三、Gson


1、gson和fastjson一样,默认是不序列化null值对应的key的,具体案例如下:

 
  1. public static void main(String[] args) throws JsonGenerationException, JsonMappingException, IOException {
  2. AutoPartsSearchRequest request = new AutoPartsSearchRequest();
  3. request.setKeywords("123");
  4. request.setSortingField("234242");
  5. Gson g = new GsonBuilder().create();
  6. String str = g.toJson(request);
  7. System.out.println(str);
  8. //输出结果:{"sortingField":"234242","keywords":"123"}
  9. }


2、若是想序列化null值对应的key,只需要将以上创建代码改成以下代码就行:

Gson g = new GsonBuilder().serializeNulls().create();
 
案例就不写了

 

3、若是想转行null为空字符串"",则需要手动处理了

 
 

 

posted @ 2018-08-14 10:35  一步之  阅读(31262)  评论(1编辑  收藏  举报