Ниже вы можете увидеть мой десериализатор «Список».

аюсь включить необработанный JSON в объект Java, когда объект (де) сериализован с использованием Джексона. Чтобы проверить эту функциональность, я написал следующий тест:

public static class Pojo {
    public String foo;

    @JsonRawValue
    public String bar;
}

@Test
public void test() throws JsonGenerationException, JsonMappingException, IOException {

    String foo = "one";
    String bar = "{\"A\":false}";

    Pojo pojo = new Pojo();
    pojo.foo = foo;
    pojo.bar = bar;

    String json = "{\"foo\":\"" + foo + "\",\"bar\":" + bar + "}";

    ObjectMapper objectMapper = new ObjectMapper();
    String output = objectMapper.writeValueAsString(pojo);
    System.out.println(output);
    assertEquals(json, output);

    Pojo deserialized = objectMapper.readValue(output, Pojo.class);
    assertEquals(foo, deserialized.foo);
    assertEquals(bar, deserialized.bar);
}

Код выводит следующую строку:

{"foo":"one","bar":{"A":false}}

JSON - это именно то, как я хочу, чтобы вещи выглядели. К сожалению, код завершается с ошибкой при попытке прочитать JSON обратно в объект. Вот исключение:

org.codehaus.jackson.map.JsonMappingException: Невозможно десериализовать экземпляр java.lang.String из токена START_OBJECT в [Source: java.io.StringReader@d70d7a; строка: 1, столбец: 13] (через цепочку ссылок: com.tnal.prism.cobalt.gather.testing.Pojo ["bar"])

Почему Джексон прекрасно работает в одном направлении, но не работает при движении в другом направлении? Похоже, что он должен быть в состоянии взять свой собственный вывод в качестве ввода снова. Я знаю, что я пытаюсь сделать, это неортодоксально (общий совет - создать внутренний объект дляbar который имеет свойство с именемA), но я не хочу взаимодействовать с этим JSON вообще. Мой код действует как проход для этого кода - я хочу взять этот JSON и снова отправить его обратно, не затрагивая ничего, потому что, когда JSON изменяется, я не хочу, чтобы мой код нуждался в изменениях.

Спасибо за совет.

РЕДАКТИРОВАТЬ: сделал Pojo статическим классом, который вызывал другую ошибку.

Ответы на вопрос(1)

Ваш ответ на вопрос