[英]JAXB: an element with textual content and attributes, generating classes with XJC
[英]Generating big enum classes with numbers in enum values JAXB, XJC
我正在尝试使用XJC生成Java类,但存在以下问题:
我正在尝试解析此架构 , 该架构是一个大的枚举类型(大于默认的typesafeEnumMaxMembers
)。 所以我使用以下绑定:
<jxb:bindings
xmlns:xs="http://www.w3.org/2001/XMLSchema"
xmlns:jxb="http://java.sun.com/xml/ns/jaxb"
version="2.1">
<!-- Raise theEnumMemberSizeCap limit -->
<jxb:bindings >
<jxb:globalBindings typesafeEnumMaxMembers="2000"/>
</jxb:bindings>
</jxb:bindings>
然后用以下代码行调用xjc:
C:\Program Files\Java\jdk1.7.0_17\bin\xjc.exe -d C:\Users\buriak\out xml\dAllDocuments_v02.1.xsd xml/binding.xjb
这没有错误,只是:
parsing a schema...
compiling a schema...
然后结束而不创建任何东西。
较小的枚举类型很容易以相同的方式进行解析,但是较大的枚举类型将被忽略,如果它们是其他xsd的其他类型的一部分-它们将简单地变成字符串:
<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema" elementFormDefault="qualified" attributeFormDefault="unqualified">
<xs:include schemaLocation="dAllDocuments_v02.1.xsd"/>
<xs:complexType name="tDocument">
<xs:annotation>
<xs:documentation>Документ - описание</xs:documentation>
</xs:annotation>
<xs:sequence>
<xs:element name="Code_Document" type="dAllDocuments">
<xs:annotation>
<xs:documentation>Код документа</xs:documentation>
</xs:annotation>
</xs:element>
...............
public class TDocument {
@XmlElement(name = "Code_Document", required = true)
protected String codeDocument;
...............
使用JAXB或XmlBeans也没有结果。
希望有人知道该怎么办。
编辑浏览了很长时间没有找到答案后,我开始思考,这不是问题的大小。 我是对的,结果发现了这一点- 具有数值的JAXB枚举
但是我要解析的XSD非常大:
<xs:simpleType name="dAllDocuments">
<xs:restriction base="xs:string">
<xs:enumeration value="008001000000"/>
<xs:enumeration value="008001001000"/>
<xs:enumeration value="008001002000"/>
<xs:enumeration value="008001003000"/>
<xs:enumeration value="008001004000"/>
<xs:enumeration value="008001005000"/>
<xs:enumeration value="008001006000"/>
<xs:enumeration value="008001007000"/>
<xs:enumeration value="008001008000"/>
<xs:enumeration value="008001009000"/>
<xs:enumeration value="008001010000"/>....
而且它持续了更长的时间。 绝对没有办法将它们全部写下来:
<jxb:bindings node="//xs:simpleType[@name='dAllDocuments']/xs:restriction/xs:enumeration[@value='008001000000']">
<jxb:typesafeEnumMember name="OOBOOIOOOOOO"/>
</jxb:bindings>
除了手动为每个值指定名称之外,还有什么方法可以使这项工作有效? 我的意思是我可以创建一个程序来使用Strings进行此类操作,但是有什么聪明的方法吗? 因为我要解析的实际XSD连接到多个此类ENUM XSD,所以我需要全部解析它们。
在花了更多时间进行研究之后,我终于设法得到了xjc等待的结果。
这是我正在使用的绑定文件,因此不会因枚举类型太大而收到警告,因此所有这些较大的枚举类型都将具有生成的名称,例如VALUE_1, VALUE_2
等。
<jxb:bindings
xmlns:xs="http://www.w3.org/2001/XMLSchema"
xmlns:jxb="http://java.sun.com/xml/ns/jaxb"
version="2.1">
<!-- Raise theEnumMemberSizeCap limit -->
<jxb:bindings >
<jxb:globalBindings typesafeEnumMaxMembers="2000" typesafeEnumMemberName="generateName"/>
</jxb:bindings>
<jxb:bindings schemaLocation="STD_Region_Cadastr.xsd">
<jxb:bindings node="//xs:complexType[@name='tRight_Owner']">
<jxb:class name="tRight_Owner2"/>
</jxb:bindings>
</jxb:bindings>
</jxb:bindings>
我还要提及的是,由于我正在解析的XSD文件具有许多西里尔字母,因此这里使用的是xjc调用:
C:\Program Files\Java\jdk1.7.0_17\bin>xjc.exe -b xml/binding.xjb -d C:\Users\buriak\out xml\STD_Region_Cadastr.xsd -encoding UTF-8
这使得几乎所有西里尔字母输入都能正确显示在Java文件中。
而已。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.