fastjson:对key为非String类型的Map的序列化和反序列问题
Posted 10km
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了fastjson:对key为非String类型的Map的序列化和反序列问题相关的知识,希望对你有一定的参考价值。
fastjson 对于key为非String类型的Map,比如
Map<Integer, Object> map = Maps.newHashMap();
map.put(12, "hello");
默认序列化为:
12:"hello"
JSON标准要求key必须为双引号括起来的String,显然上面的这个字符串不标准。
Jackson解析这个字符串就会抛出异常。
fastjson 1.2.60版本可以解析这个字符串,但是Key也不是字符串,即:12:“hello”
解决这个问题可以从两个方面处理。
序列化为标准JSON
对于Key为非String类型的Map,序列化为标准JSON,即对Key加双引号变为"12":"hello"
如下在序列化时指定WriteNonStringKeyAsString
特性,将非String类型的Key转String.按fastjson的源码中的说明从1.1.37版本就支持这个特性了。这样从数据源头就解决问题了。
Map<Integer, Object> map = Maps.newHashMap();
map.put(12, "hello");
JSON.toJSONString(map,SerializerFeature.WriteNonStringKeyAsString);
反序列化为Strng为Key的Map
fastjson 1.2.61及之后的版本在反序列化12:"hello"
时生成的Map对象的Key类型为String。再用Jackson序列就没有任何问题了。
@Test
public void test2()
Map<Integer, Object> map = Maps.newHashMap();
map.put(12, "hello");
String json = JSON.toJSONString(map);
System.out.printf("%s\\n",json);
JSONObject jsonObject = JSON.parseObject(json);
System.out.printf("jsonObject %s\\n",jsonObject);
当然也可以想办法解决jackson对非String key的Map对象的支持,但今天折腾发现挺麻烦,就没有再深入研究
以上是关于fastjson:对key为非String类型的Map的序列化和反序列问题的主要内容,如果未能解决你的问题,请参考以下文章
[fastjson] - fastjson中 JSONObject 和 JSONArray