我有这个POJO:

public class JsonObj {

    private String id;
    private List<Location> location;


    public String getId() {
        return id;
    }

    public List<Location> getLocation() {
        return location;
    }

    @JsonSetter("location")
    public void setLocation(){
        List<Location> list = new ArrayList<Location>();
        if(location instanceof Location){
            list.add((Location) location);
            location = list;
        }
    }
}

json输入中的“位置”对象可以是Location的简单实例,也可以是Location的数组。当只是一个实例时,我会收到此错误:
Could not read JSON: Can not deserialize instance of java.util.ArrayList out of   START_OBJECT token

我试图实现一个自定义的 setter ,但是没有用。如何根据json输入来映射位置或列表?

最佳答案

更新:Mher Sarkissian's soulution可以正常工作,它也可以与建议的here一起用于批注,如下所示:

@JsonFormat(with = JsonFormat.Feature.ACCEPT_SINGLE_VALUE_AS_ARRAY)
private List<Item> item;

我对这个最烦人的问题表示最深切的同情,我遇到了同样的问题,并在这里找到了解决方案:https://stackoverflow.com/a/22956168/1020871

经过一些修改,我想出了这个,首先是泛型类:
public abstract class OptionalArrayDeserializer<T> extends JsonDeserializer<List<T>> {

    private final Class<T> clazz;

    public OptionalArrayDeserializer(Class<T> clazz) {
        this.clazz = clazz;
    }

    @Override
    public List<T> deserialize(JsonParser jp, DeserializationContext ctxt)
            throws IOException {
        ObjectCodec oc = jp.getCodec();
        JsonNode node = oc.readTree(jp);
        ArrayList<T> list = new ArrayList<>();
        if (node.isArray()) {
            for (JsonNode elementNode : node) {
                list.add(oc.treeToValue(elementNode, clazz));
            }
        } else {
            list.add(oc.treeToValue(node, clazz));
        }
        return list;
    }
}

然后是属性和实际的反序列化器类(Java泛型并不总是很漂亮):
@JsonDeserialize(using = ItemListDeserializer.class)
private List<Item> item;

public static class ItemListDeserializer extends OptionalArrayDeserializer<Item> {
    protected ItemListDeserializer() {
        super(Item.class);
    }
}

10-05 23:58