1

在客户端上,我有一个在实体上运行的 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 是否可行,以及如何完成这个反序列化案例的更好想法?

谢谢

4

1 回答 1

1

TreeTraversingParser 解决了这个问题。

        JsonNode rootEntityNode = jp.readValueAsTree();
        TreeTraversingParser treeTraversingParser = new TreeTraversingParser(rootEntityNode, jp.getCodec());

在此之后,您可以分析解析的 JsonNode 的类型并使用正确的反序列化。

于 2012-09-05T15:18:11.117 回答