FastJson反序列化对象不一致的解决方法

最近在做对象属性拷贝的工作,原来使用dozerMapper,但是感觉占用内存较高,速度也不快,虽然功能很强大,可以做各种对象的映射。
因此计划使用传说中飞一般的fastJson做序列化和反序列化的方式,进行数据拷贝。
但是遇到了序列化异常的错误:

Exception in thread "main" com.alibaba.fastjson.JSONException: syntax error, expect {, actual string, pos 316
	at com.alibaba.fastjson.parser.deserializer.JavaBeanDeserializer.deserialze(JavaBeanDeserializer.java:367)
	at com.alibaba.fastjson.parser.deserializer.JavaBeanDeserializer.parseRest(JavaBeanDeserializer.java:1010)
	at com.alibaba.fastjson.parser.deserializer.FastjsonASMDeserializer_9_CustomerInfoBO.deserialze(Unknown Source)
	at com.alibaba.fastjson.parser.deserializer.JavaBeanDeserializer.deserialze(JavaBeanDeserializer.java:208)
	at com.alibaba.fastjson.parser.deserializer.FastjsonASMDeserializer_8_OrderDetailBO.deserialze(Unknown Source)

这里说一下,我这里需要拷贝的对象中存在着一个名称相同,但是类型不同的属性,一个为json格式的String,而另外一个为List,刚开始解决方向一直在错误的方向上进行,如何替换掉json各种中的双引号,让他自动序列化。

最后无意间发现@JSONField注解中存在着deserializeUsing属性,也就是反序列化时可以自定义自己的反序列化类,于是写了一个继承ObjectDeserializer的类,问题得以解决。

 public static final class CustomerListSerializer implements ObjectDeserializer {

		@Override
		public <T> T deserialze(DefaultJSONParser defaultJSONParser, Type type, Object o) {
			List<String> json = defaultJSONParser.parseObject(List.class);
	
			List<Entity> datas= new ArrayList<>();
			for(int i=0;i<json.size();i++){
				Entity bo = JSON.parseObject(json.get(i),Entity.class);
				bo.setRoomSeq(i+1);
				datas.add(bo);
			}
			return (T)datas;
		}

		@Override
		public int getFastMatchToken() {
			return 0;
		}
	}

希望可以帮助更多的人~~

猜你喜欢

转载自blog.csdn.net/zfy1355/article/details/86581937