多级多态树应该不是杰克逊的问题。这是一个序列化/反序列化类层次结构的示例,类似于您在the Jackson wiki page. 中的问题中的内容@
public class JacksonPolymorphism3 {
@JsonTypeInfo(
use = JsonTypeInfo.Id.NAME,
include = JsonTypeInfo.As.PROPERTY,
property = "type")
public abstract static class Animal {
public final String animalField;
@JsonCreator
public Animal(@JsonProperty("animalField") String animalField) {
this.animalField = animalField;
}
}
@JsonTypeName("dog")
public static class Dog extends Animal {
public final String dogField;
public Dog(@JsonProperty("animalField") String animalField,
@JsonProperty("dogField") String dogField) {
super(animalField);
this.dogField = dogField;
}
@Override
public String toString() {
return "Dog{" +
"dogField='" + dogField + '\'' +
'}';
}
}
@JsonTypeName("husky")
public static class Husky extends Dog {
public final String huskyField;
public Husky(@JsonProperty("animalField") String animalField,
@JsonProperty("dogField") String dogField,
@JsonProperty("huskyField") String huskyField) {
super(animalField, dogField);
this.huskyField = huskyField;
}
@Override
public String toString() {
return "Husky{" +
"huskyField='" + huskyField + '\'' +
'}';
}
}
public static void main(String[] args) throws IOException {
List<Dog> dogs;
dogs = Arrays.asList(new Dog("aField", "dogField"), new Husky("hField", "dField2", "hField"));
ObjectMapper mapper = new ObjectMapper();
mapper.registerSubtypes(Dog.class, Husky.class);
TypeReference<List<Dog>> referenceType = new TypeReference<List<Dog>>() {
};
String json = mapper.writerWithDefaultPrettyPrinter().withType(referenceType).writeValueAsString(dogs);
System.out.println(json);
System.out.println(mapper.readValue(json, referenceType));
}
}
输出:
[ {
"type" : "dog",
"animalField" : "aField",
"dogField" : "dogField"
}, {
"type" : "husky",
"animalField" : "hField",
"dogField" : "dField2",
"huskyField" : "hField"
} ]
[Dog{dogField='dogField'}, Husky{huskyField='hField'}]
如果没有帮助,请提供更多代码。