让我说我有课
@XmlType(propOrder = {
"one",
"two"
})
@XmlRootElement(name = "search")
public class Search {
protected One one;
protected Two two;
//getters & setters
}
我想要一个扩展这个类的类
e.g。
@XmlType(propOrder = {
"three"
})
@XmlRootElement(name = "searchExtended")
public class SearchExtended extends Search {
protected Three three;
//getters & setters
}
你如何正确地声明propOrder,我之前尝试过这个并且它没有使用我认为的那样的命令。这是如何通过注释处理的? /你应该如何在扩展类中声明这个?
答案 0 :(得分: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;
}
});
}
}