6

可以说我有课

@XmlType(propOrder = {
        "one",
        "two"
    })

@XmlRootElement(name = "search")
public class Search {

    protected One one;  
    protected Two two;

    //getters & setters
}

我想要一个扩展这个类的类

例如

@XmlType(propOrder = {
        "three"
    })

@XmlRootElement(name = "searchExtended")
public class SearchExtended extends Search {

    protected Three three;  
    //getters & setters
}

您如何正确声明 propOrder,我之前尝试过,但它没有使用我认为的顺序。注释是如何处理的?/ 你应该如何在扩展类中声明这个?

4

1 回答 1

8

父属性将根据其在子属性之前的指定顺序进行编组。propOrder如果用 注释父类,则可以在子类的中包含父类的属性@XmlTransient


更新

有什么办法可以让它瞬变但仍然可以正常使用吗?

不,@XmlTransient对类进行设置会将其从 JAXB 认为已映射的类中删除。JAXB 将超类的属性编组在子类的属性之前的原因是为了匹配 XML 模式的规则。当您的Search类没有标记@XmlTransient相应的 XML 模式时,如下所示。根据 XML 模式规则,为了使类型searchExtended元素有效,超类型中的元素必须出现在子类型中定义的任何元素之前。

  <xs:complexType name="searchExtended">
    <xs:complexContent>
      <xs:extension base="search">
        <xs:sequence>
          <xs:element name="three" type="three" minOccurs="0"/>
        </xs:sequence>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>

  <xs:complexType name="search">
    <xs:sequence>
      <xs:element name="one" type="one" minOccurs="0"/>
      <xs:element name="two" type="two" minOccurs="0"/>
    </xs:sequence>
  </xs:complexType>

您可以通过运行以下代码来查看与您的 JAXB 模型对应的 XML 模式:

import java.io.IOException;
import javax.xml.bind.*;
import javax.xml.transform.Result;
import javax.xml.transform.stream.StreamResult;

public class Demo {

    public static void main(String[] args) throws Exception {
        JAXBContext jc = JAXBContext.newInstance(SearchExtended.class);
        jc.generateSchema(new SchemaOutputResolver() {

            @Override
            public Result createOutput(String namespaceUri,
                    String suggestedFileName) throws IOException {
                StreamResult result = new StreamResult(System.out);
                result.setSystemId(suggestedFileName);
                return result;
            }

        });
    }

}
于 2012-09-18T10:52:32.557 回答