您可以指定反序列化器类,使用该类对带有注释
contentUsing属性的列表元素进行反序列化
@JsonDeserializer。
public class Citizen { ... @JsonDeserializer(contentUsing=MyListDeserializer.class) public void setTickets(List<Tickets> tickets) { this.tickets = tickets; }}
使解串器扩展,
JsonDeserializer<baseClass>并在baseClass中具有一个属性,该属性存储具体类的实际类型。
abstract class baseTickets { String ticketType; public String getTicketType()}public class MyListDeserializer extends JsonDeserializer<baseTickets> { @Override public baseTickets deserialize(JsonParser jsonParser, DeserializationContext arg1) throws IOException, JsonProcessingException { ObjectCodec oc = jsonParser.getCodec(); JsonNode node = oc.readTree(jsonParser); Iterator<JsonNode> elements = node.getElements(); for (; elements.hasNext();) { String type = (String) elements.next().get("ticketType"); if (type.equals()){ //create concrete type here } } }
或者,如果您要为所有没有通用基类的List类型使用一个反序列化器,则可以使用
using属性具有
MyListDeserializerextend
JsonDeserialize<Object>。为了确定list元素的类型,您必须编写一个自定义的序列化程序,将类型信息添加到列表中,然后可以在通用反序列化程序中使用它。
public class Citizen { ... @JsonDeserializer(using=MyListDeserializer.class) @JsonSerializer(using=MyListSerializer.class) public void setTickets(List<Tickets> tickets) { this.tickets = tickets; }}public class MyListSerializer extends JsonSerializer<Object> { @Override public void serialize(Object list, JsonGenerator jgen, SerializerProvider provider) throws IOException, JsonProcessingException { @SuppressWarnings("rawtypes") jgen.writeStartObject(); String type = getListType(list); jgen.writeStringField("listType", type); jgen.writeObjectField("list", list) }}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)