我们通过 xcj
使用模式中生成的对象类型 . 因此,对类型的定义不是非常灵活的控制 . 我们还使用JAXB注释 .
然后,我们使用Jackson Faster XML对这些对象进行反序列化 . 不幸的是,当我们反序列化抽象类时,我们得到一个例外:
com.fasterxml.jackson.databind.JsonMappingException: Can not construct instance of
com.x.y.z.AnstractType: abstract types either need to be mapped to concrete types,
have custom deserializer, or contain additional type information at
[Source: org.glassfish.jersey.message.internal.ReaderInterceptorExecutor$UnCloseableInputStream@2989b3db;
line: 1, column: 625] (through reference chain: com.x.y.z.TypeA["type-b-prop"]->
com.x.y.z.TypeB["type-c-prop"]->java.util.ArrayList[0]->
com.x.y.z.TypeC["abstract-type-prop"]->java.util.ArrayList[0])
通过添加mixin,可以轻松地为抽象类的单个子项解决上述问题:
@JsonTypeInfo(defaultImpl = ChildType.class, use = JsonTypeInfo.Id.MINIMAL_CLASS, include = JsonTypeInfo.As.PROPERTY, property = "@class")
static class AbstractTypeMixIn {
}
并在对象映射器中注册它:
objectMapper = new ObjectMapper();
objectMapper.addMixIn(AbstractType.class, AbstractTypeMixIn.class);
...
objectMapper.registerModule(new JaxbAnnotationModule());
当单个类继承抽象类时,这就像一个魅力 . 多个孩子怎么样?知道如何为抽象类的多个继承者实现它吗?如果不是mixins,还有什么?
2 回答
问题是我只使用mixin来解析响应,而不是写它 . 因此,解决方案是使用相同的mixins作为对象映射器进行序列化和反序列化 . 以下定义就足够了:
它只是在JSON中为不明确的子类添加
@type
属性 .@JsonSubTypes
注释可能对您有用 . 有关详细信息,请参阅Is Jackson's @JsonSubTypes still necessary for polymorphic deserialization?