我正在用Jackson解析以下外部XML。
<SomeRootObject>
<Events>
<Event>
<EventID>248739296</EventID>
...
<Event>1709</Event>
...
我为“事件”定义了POJO。
@JacksonXmlRootElement(localName = "Event")
public class MyEvent {
@JsonProperty("EventID")
public String eventID;
...
@JsonProperty("Event")
public int event;
...
如您所见,此POJO中的一个字段也被映射为“事件”。因此,杰克逊(Jackson)抱怨说无法通过事件创建整数:
com.fasterxml.jackson.databind.JsonMappingException: Can not deserialize instance of int out of START_OBJECT token
at [Source: java.io.StringReader@12417468; line: 1, column: 280] (through reference chain: be.parkd.api.tnt.ram.model.RamEvents[“Event”]->java.util.ArrayList[0]->be.parkd.api.tnt.ram.model.RamEvent[“Event”]).
杰克逊可以处理此案吗?
我想到的一个肮脏的解决方法是对XML进行预处理以更改基础事件,但是我希望使用更干净的解决方案。
答案 0 :(得分:2)
以下示例读取包装在<Event>
元素中的<Events>
个元素的列表。 <Event>
本身包含另一个嵌套的<Event>
元素。对于Jackson来说,这似乎不是问题。
注意:我使用TypeReference<List<Event>>() {}
作为序列化规则。
@Test
public void test2() throws JsonParseException, JsonMappingException, IOException {
ObjectMapper mapper = new XmlMapper();
List<Event> event=mapper.readValue("<Events><Event><EventID>248739296</EventID><Event>1709</Event></Event><Event><EventID>248739297</EventID><Event>1710</Event></Event></Events>", new TypeReference<List<Event>>() {
});
System.out.println(toString(event));
}
public String toString(Object obj) {
try {
StringWriter w = new StringWriter();
new ObjectMapper().configure(SerializationFeature.INDENT_OUTPUT, true).writeValue(w, obj);
return w.toString();
} catch (Exception e) {
throw new RuntimeException(e);
}
}
使用Event.java
@JacksonXmlRootElement(localName = "Event")
public class Event {
@JsonProperty("EventID")
private String eventID;
@JsonProperty("Event")
private int event;
public String getEventID() {
return eventID;
}
public void setEventID(String eventID) {
this.eventID = eventID;
}
public int getEvent() {
return event;
}
public void setEvent(int event) {
this.event = event;
}
}
打印
[ {
"EventID" : "248739296",
"Event" : 1709
}, {
"EventID" : "248739297",
"Event" : 1710
} ]
所以,它有效!