当前位置: 首页 > 知识库问答 >
问题:

带有 JAXB 类包装器的 Java 解封对象列表

颛孙安康
2023-03-14

从 BaseX 服务器执行的 X 查询中,我得到这样的结果:

<ProtocolloList>
  <protocollo>
    <numero>1</numero>
    <data>2014-06-23</data>
    <oggetto/>
    <destinatario/>
    <operatore/>
  </protocollo>
     ...
</ProtocolloList>

我需要用JAXB将这个结果转换成Protocollo对象的列表,以便用JList显示它们。因此,在这里的一次讨论之后,我声明了下面的类:

import javax.xml.bind.annotation.XmlElement;
import javax.xml.bind.annotation.XmlRootElement;

@XmlRootElement(name = "protocollo")
public class Protocollo {

  private int numero;
  private String data;
  private String oggetto;
  private String destinatario;
  private String operatore;

  public Protocollo(String d, String o, String des, String op) {
    this.data = d;
    this.oggetto = o;
    this.destinatario = des;
    this.operatore = op;
  }

  public Protocollo() {

  }

  @XmlElement
  public int getNumero() {
      return numero;
  }

  public void setNumero(int numero) {
      this.numero = numero;
  }

  @XmlElement
  public String getData() {
      return data;
  }

  public void setData(String data) {
      this.data = data;
  }

  @XmlElement
  public String getOggetto() {
      return oggetto;
  }

  public void setOggetto(String oggetto) {
      this.oggetto = oggetto;
  }

  @XmlElement
  public String getDestinatario() {
      return destinatario;
  }

  public void setDestinatario(String destinatario) {
      this.destinatario = destinatario;
  }

  @XmlElement
  public String getOperatore() {
      return operatore;
  }

  public void setOperatore(String operatore) {
      this.operatore = operatore;
  }

}

import java.util.ArrayList;

import javax.xml.bind.annotation.XmlElement;
import javax.xml.bind.annotation.XmlElementWrapper;
import javax.xml.bind.annotation.XmlRootElement;

@XmlRootElement(name = "ProtocolloList")
public class ProtocolloList {

  @XmlElementWrapper(name = "ProtocolloList")
  @XmlElement(name = "protocollo")
  private ArrayList<Protocollo> ProtocolloList;

  public ArrayList<Protocollo> getProtocolloList() {
      return ProtocolloList;
  }

  public void setProtocolloList(ArrayList<Protocollo> protocolloList) {
      ProtocolloList = protocolloList;
  }
}

最后,我这样执行对话:

JAXBContext jaxbContext = JAXBContext.newInstance(Protocollo.class);
Unmarshaller unmarshaller = jaxbContext.createUnmarshaller();
StringReader reader = new StringReader(this.resultXML);
protocolli = (ProtocolloList) unmarshaller.unmarshal(reader);

我不断得到这个例外:

unexpected element (uri:"", local:"ProtocolloList"). Expected elements are <{}protocollo>

我想我在注释方面犯了一些错误。你能帮忙吗?

共有1个答案

斜淳
2023-03-14

对于您的用例,您不需要@XmlElementWrapper注释。这是因为ProtocolList元素对应于您的@XmlRootElement注释。然后您需要属性上的@XmlElement注释来获取每个列表项。

@XmlRootElement(name = "ProtocolloList")
public class ProtocolloList {

  private ArrayList<Protocollo> ProtocolloList;

  @XmlElement(name = "protocollo")
  public ArrayList<Protocollo> getProtocolloList() {
      return ProtocolloList;
  }

}

注意:

默认情况下,您应该注释该属性。如果您想要注释这些字段,您应该将< code > @ XmlAccessorType(XmlAccessType。FIELD)。

您需要确保 JAXB 上下文知道根类。您可以将 JAXB 上下文创建代码更改为如下所示:

JAXBContext jaxbContext = JAXBContext.newInstance(ProtocolloList.class);
 类似资料:
  • 我有如下所示的XML: 我有一个ObjectList类,它如下所示: 和如下所示的对象类: 当我尝试使用以下代码将xml解封到and对象中时: 我得到以下错误: UnMarshalException:意外元素(URI:“”,本地:“ObjectList”)。需要的元素为<{}Object>、<{}ObjectList> 编辑:我刚刚注意到两个问题我将我的ObjectList对象的XmlRootEl

  • 我对JAXB很陌生,在解封一般对象时遇到了麻烦。问题是我需要能够封送和解封任何对象(java.lang.object)。我成功地进行了封送处理,但是当我运行解封处理时,响应中得到的是一个“ElementNSimpl”对象,而不是我自己的对象。 这是涉及的bean: message.java somebean.java jaxb.index的内容: 生成的xml很好()但是在解封后计算“msg.ge

  • 我正在使用Java 8流,并试图修改forEach终端操作中的对象内容。 我在这里面临的问题是,我可以修改对象内容,但不能修改的内容 代码片段如下: 我想知道,由于在执行操作时取消了整数对象的装箱,所以该更改不会反映在列表中,但不确定。

  • 我有 和Xlink类,该类在内联变量中工作良好。 对于的XML输入 并且子课程拒绝被取消注册(没有任何异常被抛出)。 注:不幸的是,MOXy不是一个选项。 编辑:新编组对象 Edit2:在对测试对象进行了一些解组和编组的实验之后,我发现我需要在内容的标题中定义xmlns名称空间,以便与类似问题在于,我从一个包装类中获取Course元素,该包装类由resteasy解析出来。因此,生成的类不会携带名称

  • 我使用JAXB将一些xml解组到一个对象中。 我有一个从抽象类继承的类。我已经将抽象类标记为@XmlTransient。然后使用XMLType PropOrder,我可以访问抽象类中的属性,如下所示: 凉。问题是有时它不是我想访问的元素,而是一个属性。通常,您将使用@XMLAttribute来定义此类属性,以指示值存储在 xml 特性而不是元素中。但是,鉴于我已经在定义了“id”的抽象类上使用了

  • 同样,在导出时没有错误。问题是getCityWeatherbyZipresponse.getCityWeatherbyZipResult的值为null。我知道文档正在返回正确的结果,因为结果打印如下: 结果打印输出: 测试Web服务:http://wsf.cdyne.com/weatherws/weather.asmx 子umarshal对象: