fastjson 对于key为非String类型的Map,比如
Map<Integer, Object> map = Maps.newHashMap();
map.put(12, "hello");
- 1
- 2
默认序列化为:
{12:"hello"}
- 1
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);
- 1
- 2
- 3
反序列化为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);
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
当然也可以想办法解决jackson对非String key的Map对象的支持,但今天折腾发现挺麻烦,就没有再深入研究