2

我将 JAXB 与 CXF Web 服务一起使用。当我通过时:

<?xml version="1.0" ?><ns2:Optionen xmlns:ns2="http://test.at/ezustellung/global/20090501#">
<ns2:PdfAKonvertierung>true</ns2:PdfAKonvertierung><ns2:SignaturTyp>Adobe</ns2:SignaturTyp>
</ns2:Optionen>

对于 Unmarshaller,属性 pdfAKonvertierung 和 signaturTyp 在我的对象中都是空的。但如果我通过:

<?xml version="1.0" ?><ns2:Optionen xmlns:ns2="http://test.at/ezustellung/global/20090501#">
<PdfAKonvertierung>true</PdfAKonvertierung><SignaturTyp>Adobe</SignaturTyp>
</ns2:Optionen>

这是无效的,根据 CXF Validator 和维基百科(翻译,没有找到英文):

具有命名空间前缀的元素的子元素不会自动具有相同的命名空间,它们也必须以命名空间作为前缀。

相应地设置属性。有人能在我的代码中发现错误吗,或者我是否在 Java 1.6 的 JAXB 实现中发现了错误?

作为参考,这是我的代码:

 public class JaxbTests {
  @Test
  public void testOptionen() throws JAXBException, SAXException, IOException {
   JAXBContext context = JAXBContext.newInstance(Optionen.class);
   Unmarshaller unmarshaller = context.createUnmarshaller();
   ByteArrayInputStream is = new ByteArrayInputStream(
     // Does not work
     ("<?xml version=\"1.0\" ?><ns2:Optionen xmlns:ns2=\"http://test.at/ezustellung/global/20090501#\">" +
     "<ns2:PdfAKonvertierung>true</ns2:PdfAKonvertierung><ns2:SignaturTyp>Adobe</ns2:SignaturTyp>" +
     "</ns2:Optionen>").getBytes());

     // Works
 //    ("<?xml version=\"1.0\" ?><ns2:Optionen xmlns:ns2=\"http://test.at/ezustellung/global/20090501#\">" +
 //    "<PdfAKonvertierung>true</PdfAKonvertierung><SignaturTyp>Adobe</SignaturTyp>" +
 //    "</ns2:Optionen>").getBytes());
   Optionen opts = ((Optionen) unmarshaller.unmarshal(is));
   Assert.assertTrue(opts.isPdfAKonvertierung() == true);
   Assert.assertEquals(SignaturTypType.ADOBE, opts.getSignaturTyp());
  }
 }


 @XmlAccessorType(XmlAccessType.FIELD)
 @XmlType(name = "", propOrder = {
     "pdfAKonvertierung",
     "signaturTyp"
 })
 @XmlRootElement(name = "Optionen")
 public class Optionen {

     @XmlElement(name = "PdfAKonvertierung", defaultValue = "true")
     protected Boolean pdfAKonvertierung;
     @XmlElement(name = "SignaturTyp", defaultValue = "Adobe")
     protected SignaturTypType signaturTyp;

     public Optionen() {
      System.out.println("Optionen created");
     }
     public Boolean isPdfAKonvertierung() {
         return pdfAKonvertierung;
     }
     public void setPdfAKonvertierung(Boolean value) {
         this.pdfAKonvertierung = value;
     }
     public SignaturTypType getSignaturTyp() {
         return signaturTyp;
     }
     public void setSignaturTyp(SignaturTypType value) {
         this.signaturTyp = value;
     }

 }


 @XmlType(name = "SignaturTypType")
 @XmlEnum
 public enum SignaturTypType {

  @XmlEnumValue("Adobe")
  ADOBE("Adobe"), @XmlEnumValue("PDF-AS")
  PDF_AS("PDF-AS");
  private final String value;

  SignaturTypType(String v) {
   this.value = v;
  }

  public String value() {
   return this.value;
  }

  public static SignaturTypType fromValue(String v) {
   for (SignaturTypType c : SignaturTypType.values()) {
    if (c.value.equals(v)) {
     return c;
    }
   }
   throw new IllegalArgumentException(v);
  }

 }

包信息.java:

@javax.xml.bind.annotation.XmlSchema(namespace = "http://test.at/ezustellung/global/20090501#")
package at.test.ezustellung.global._20090501_;
4

2 回答 2

5

该问题的解决方案(不修改生成的类)是确保

<xs:schema elementFormDefault="qualified">

属性存在并重新生成 jaxb 映射,因此

elementFormDefault = javax.xml.bind.annotation.XmlNsForm.QUALIFIED

最终出现在 package-info.java

于 2010-03-09T18:09:07.907 回答
2

阅读格式不正确的代码有点困难,但是如果您使用正确的名称空间声明元素,它不会解决您的问题,例如@XmlElement(namespace = "http://test.at/ezustellung/global/20090501#", name = "SignaturTyp", defaultValue = "Adobe")

于 2010-03-08T19:50:37.913 回答