提问者:小点点

jackson xmlmapper for map<String,Object>,react for specific tag


我有这样的xml结构:

    <Result>
      <ReferenceMin>4</ReferenceMin>
      <ReferenceMax>5.65</ReferenceMax>
      <PrecedingValue>3.25</PrecedingValue>
      <PrecedingDate><Date year="2017"  month="04"    day="21"/></PrecedingDate>
    </Result>

这种xml来自无法控制的第三方服务,它可以包含新字段,或者现有字段可以消失,因此我无法为对象定义严格的结构。如我所见,除precingdate外,所有字段都可以解析为“String”。

是否可以通过我的cyustom策略教jackson xmlMapper使用PrecedingDate或Date字段工作?目前它创建具有以下结构的对象:

{PrecedingDate: Date: {year: 2017, month: 04, day: 21}}

我想要java date或instant或类似的东西。


共1个答案

匿名用户

您可以实现自定义反序列化程序或使用JsonAnySetter注释。如何使用注释,您可以在下面找到:

import com.fasterxml.jackson.annotation.JsonAnySetter;
import com.fasterxml.jackson.dataformat.xml.XmlMapper;

import java.io.File;
import java.time.LocalDate;
import java.util.HashMap;
import java.util.Map;

public class XmlMapperApp {

    public static void main(String[] args) throws Exception {
        File xmlFile = new File("./resource/test.xml").getAbsoluteFile();

        XmlMapper xmlMapper = new XmlMapper();
        System.out.println(xmlMapper.readValue(xmlFile, Result.class));
    }
}

class Result {

    private Map<String, String> entries = new HashMap<>();
    private LocalDate precedingDate;

    public Map<String, String> getEntries() {
        return entries;
    }

    public LocalDate getPrecedingDate() {
        return precedingDate;
    }

    @JsonAnySetter
    public void setEntry(String key, Object value) {
        if ("PrecedingDate".equals(key)) {
            Map<String, String> date = (Map<String, String>)((Map) value).get("Date");
            precedingDate = LocalDate.of(
                    Integer.parseInt(date.get("year")),
                    Integer.parseInt(date.get("month")),
                    Integer.parseInt(date.get("day")));
        } else {
            entries.put(key, value.toString());
        }
    }

    @Override
    public String toString() {
        return "Result{" +
                "entries=" + entries +
                ", precedingDate=" + precedingDate +
                '}';
    }
}

以上代码打印:

Result{entries={ReferenceMin=4, PrecedingValue=3.25, ReferenceMax=5.65}, precedingDate=2017-04-21}

相关问题