在客户端上,我有一个在实体上运行的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并且可能更好地了解如何完成此反序列化案例,有人可以发表评论吗?
谢谢
答案 0 :(得分:1)
TreeTraversingParser解决了这个问题。
JsonNode rootEntityNode = jp.readValueAsTree();
TreeTraversingParser treeTraversingParser = new TreeTraversingParser(rootEntityNode, jp.getCodec());
在此之后,您可以分析已解析的JsonNode类型,并使用正确的序列进行反序列化。