具有更多名称的JAXB @XmlElement

时间:2019-03-27 14:34:54

标签: java jaxb unmarshalling xmlelement

我有一个带信封的xml,在信封中有一个标头,在标头中有一个名为Period的元素,带有Startdate和Enddate。但是在某些情况下,它们被称为StartDate和EndDate。取消编组时,JAXB会同时寻找两者吗?

我已经有了一个Envelope类,其中包含一堆我需要的所有父元素类,如果需要,每个子元素都有子元素。其中之一是Period类,其中有两个@XmlElement public String ***date

我用unmarshall解析它,然后访问我的InsertProcessor中的数据 将它们放在查询中并保存到数据库中。

我尝试使用@XmlElements({}),但没有用:

@XmlElements({
    @XmlElement(name = "Startdate", type = Startdate.class),
    @XmlElement(name = "StartDate", type = StartDate.class)
})
private DateStart startdate;
@XmlElements({
    @XmlElement(name = "Enddate", type = Enddate.class),
    @XmlElement(name = "EndDate", type = EndDate.class)
})
private DateEnd enddate;

public Startdatum getStartdate() {
   return startdate;
}

public Stopdatum getEnddate() {
   return enddate;
}

abstract class DateStart{}

private class Startdate extends DateStart{}

private class StartDate extends DateStart{}

abstract class DateEnd{}

private class Enddate extends DateEnd{}

private class EndDate extends DateEnd{}

尝试通过env.Header.Period.getStartdate();在InsertProcessor.java中访问它

IDE用Incompatible types. Required String, Found Parser.Startdatum

响应

Sample.xml

<envelope>
 <data>
  <msgcode>441</msgcode>
  <msgdate>201903151120000</msgdate>
 </data>
 <Message>
  <Header>
   <Period>
     <Startdate>2018-05-01</Startdate> <!-- can also be StartDate -->
     <Enddate>2018-05-31</Enddate> <!-- can also be EndDate -->
   </Period>
  </Header>
 </Message>
</envelope>

Parser.java

public class Parser {
 public static Envelope parse (String xml) throws JAXBException, SAXException {
  JAXBContext jc;
  jc = JAXBContent.newInstance(Envelope.class)
  Unmarshaller u = jc.createUnmarshaller();
  ...
  InputSource is = new InputSource(new StringReader(xml));
  return (Envelope) u.unmarshal(new SAXSource(inFiler, inputSource));
 }
 @XmlRootElement(name="Envelope")
 public static class Envelope {
  @XmlElement(name = "Data")
  public Data Data;
  @XmlElement(name = "Message")
 public Message Message;
 }
 ...
 public static class Message {
 @XmlElement(name = "Header")
 public Header Header;
 ...
 }
 public static class Header {
 @XmlElement(name = "Period")
 public Period Period;
 ...
 }
 public static class Period {
 @XmlElement(name = "Startdate")
 public String Startdate;
 @XmlElement(name = "Enddate")
 public String Enddate;
 }
...
}

InsertProcessor.java:

public class InsertProcessor {
 public void process(String xml) throws Exception {
  Parser.Envelope env = Parser.parse(xml);
  String id = env.Header.Identification;
  ...
  String Startdate = env.Header.Period.Startdate;
  String Enddate = env.Header.Period.Enddate;

  try (Connection c = Db.getConnection()) {
   PreparedStatement ps = c.prepareStatement("insert into...");
    ps.setString(1, id)
    ...
    ps.setString(9, Startdate);
    ps.setString(10, Enddate);
    ps.execute();
  }
}

所以我需要获取Start / Enddate或Start / EndDate。现在我刚开始/结束日期

0 个答案:

没有答案