![](/img/trans.png)
[英]Jackson deserialize two different Json representations in one POJO
[英]How to deserialize different object representations to a POJO?
在客户端上,我有一个对实体进行操作的Javascript应用程序,其中的某些对象是通过包装对象引用的,该对象包含服务器端实例的唯一键-基本上是某种引用。 有些是按原样处理的,所有实体字段都存在。
当我发送带有修改的实体以将其持久保存在服务器上时,某些本身是实体的字段是引用,有些是完整的对象。
例如,假设我有Car,CarModel和Garage,则传入的JSON可能如下所示:
{
addedItems: [{
"@class": "mydoamin.Car",
belongsTo: {
"key": "Unique_Garage_Key"
},
carModel: {
name: "New Car Model",
wheelSize: 14,
doors: 5
}
},{
"@class": "mydomain.Car",
belongsTo: {
"name": "New Garage"
},
carModel: {
key: "Unique_Key_Of_Existing_Car_Model"
}
}]
}
为此,我需要一个灵活的反序列化程序,该程序可以将两种格式反序列化为相应的域POJO。
从杰克逊文档中获得的信息,我启动了一个反序列化器,但是我不知道如何正确编写它。 我在反序列化器中得到的是JsonParser和DeserializationContext。 而且我认为可以通过将流解析两次来实现,首先将其作为包装对象,如果失败,则尝试将其读取为域对象。 不幸的是,我看不到JsonParser可以做到这一点。
所以基本上我的反序列化方法是:
Car car;
try {
Wrapper carRef = jp.readValueAs(Wrapper.class);
car = wrapper.unwrap(carRef);
} catch (Exception e) {
// rewind the stream somehow...
car = jp.readValueAs(Car.class);
}
有人可以评论一下JsonParser是否可行,以及如何完成反序列化案例的更好的主意吗?
谢谢
TreeTraversingParser解决了该问题。
JsonNode rootEntityNode = jp.readValueAsTree();
TreeTraversingParser treeTraversingParser = new TreeTraversingParser(rootEntityNode, jp.getCodec());
之后,您可以分析解析的JsonNode的类型并使用正确的序列进行反序列化。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.