fastjson:对key为非String类型的Map的序列化和反序列化问题_map序列化和反序列化_10km的博客

CSDN博客 · · 592 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

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

592 次点击  
加入收藏 微博
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传