Джексон с JSON: нераспознанное поле, не помеченное как игнорируемое - PullRequest
558 голосов
/ 20 декабря 2010

Мне нужно преобразовать определенную строку JSON в объект Java. Я использую Джексона для обработки JSON. У меня нет контроля над вводом JSON (я читаю из веб-службы). Это мой ввод JSON:

{"wrapper":[{"id":"13","name":"Fred"}]}

Вот упрощенный вариант использования:

private void tryReading() {
    String jsonStr = "{\"wrapper\"\:[{\"id\":\"13\",\"name\":\"Fred\"}]}";
    ObjectMapper mapper = new ObjectMapper();  
    Wrapper wrapper = null;
    try {
        wrapper = mapper.readValue(jsonStr , Wrapper.class);
    } catch (Exception e) {
        e.printStackTrace();
    }
    System.out.println("wrapper = " + wrapper);
}

Мой класс сущности:

public Class Student { 
    private String name;
    private String id;
    //getters & setters for name & id here
}

Мой класс Wrapper - это, по сути, контейнерный объект для получения моего списка учеников:

public Class Wrapper {
    private List<Student> students;
    //getters & setters here
}

Я получаю эту ошибку, и "обертка" возвращает null. Я не уверен, чего не хватает. Может кто-нибудь помочь, пожалуйста?

org.codehaus.jackson.map.exc.UnrecognizedPropertyException: 
    Unrecognized field "wrapper" (Class Wrapper), not marked as ignorable
 at [Source: java.io.StringReader@1198891; line: 1, column: 13] 
    (through reference chain: Wrapper["wrapper"])
 at org.codehaus.jackson.map.exc.UnrecognizedPropertyException
    .from(UnrecognizedPropertyException.java:53)

Ответы [ 34 ]

0 голосов
/ 10 декабря 2015

Вы должны просто изменить поле List с «студентов» на «обертку», просто файл json, и маппер найдет его.

0 голосов
/ 07 апреля 2018

Измените класс Wrapper на

public Class Wrapper {

          @JsonProperty("wrapper")  // add this line
          private List<Student> students;
}

Это значит, что поле students распознается как ключ wrapper объекта json.

Также я лично предпочитаю использовать Lombok Annotations для геттеров и сеттеров как

@Getter
@Setter
public Class Wrapper {

          @JsonProperty("wrapper")  // add this line
          private List<Student> students;
}

Поскольку я не тестировал вышеупомянутый код с Lombok и @JsonProperty вместе, я предлагаю вам добавить следующий код в класс Wrapper какможно переопределить методы получения и установки по умолчанию Lombok.

public List<Student> getWrapper(){
     return students;
}

public void setWrapper(List<Student> students){
     this.students = students;
}

Также отметьте this для десериализации списков с использованием Джексона.

0 голосов
/ 21 февраля 2017

Вам необходимо проверить все поля класса, в котором вы анализируете, сделать так же, как в вашем исходном JSONObject.Это помогло мне и в моем случае.

@JsonIgnoreProperties(ignoreUnknown = true) не помогло вообще.

0 голосов
/ 20 февраля 2018

В моем случае ошибка произошла по следующей причине

  • Сначала все работало нормально, потом я переименовал одну переменную, сделал изменения в коде, и это дало мне эту ошибку.

  • Затем я применил свойство невежества Джексона, но оно не сработало.

  • Наконец, после переопределения моих методов получения и установки согласно имя моей переменной эта ошибка была исправлена ​​

Так что убедитесь, что вы также доработали геттеры и сеттеры.

...