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对象的支持,但今天折腾发现挺麻烦,就没有再深入研究

Logo

魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。

更多推荐