当使用杰克逊(反)序列化对象时,我试图在 Java 对象中包含原始 JSON。为了测试此功能,我编写了以下测试:
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:无法从 [Source: java.io.StringReader@d70d7a; 的 START_OBJECT 令牌中反序列化 java.lang.String 的实例;行:1,列:13](通过参考链:com.tnal.prism.cobalt.gather.testing.Pojo["bar"])
为什么杰克逊在一个方向上运行得很好,但在另一个方向上却失败了?似乎它应该能够再次将自己的输出作为输入。我知道我正在尝试做的是非正统的(一般建议是为它创建一个bar
具有名为的属性的内部对象A
),但我根本不想与这个 JSON 交互。我的代码充当此代码的传递——我想接收此 JSON 并将其再次发送回而不触及任何东西,因为当 JSON 更改时,我不希望我的代码需要修改。
感谢您的建议。
编辑:使 Pojo 成为一个静态类,这导致了不同的错误。