1

我使用 XML 模式定义和 JAXB 来生成带有适当@XmlElement@XmlRootElement注释的 Java 类。

由于模式中有一些深层嵌套(不是我的选择),我宁愿使用jxpathXPath 来访问深埋的类(而不是繁琐的.getThat()and菊花链that != null)。

问题是某些 XML 元素名称包含破折号,例如foo-bar. 当我尝试使用 访问元素org.apache.jxpath时,我需要重写我的 XPath,以便将这些名称改为驼峰式 ( fooBar),就像实际 Java 对象的名称一样。有没有办法告诉jxpath使用与 XML 元素名称相对应的 XPath 查找元素(而不是骆驼大小写的 Bean 名称)?

我认为这与这个问题有关,但是在我的情况下,只要 xjc 可以做到,我实际上并不知道在自动生成的类上使用了什么样的技巧和装饰。

这是一个简单的例子来说明这个问题。

首先,一个小的 XSD 文件:

<?xml version="1.0" encoding="UTF-8"?>
<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema" elementFormDefault="qualified">
  <xs:element name="record">
    <xs:complexType>
      <xs:sequence>
        <xs:element name="foo-bar" type="xs:string"/>
      </xs:sequence>
    </xs:complexType>
  </xs:element>
</xs:schema>

编译它...

xjc -p org.pd.jx example.xsd 

这是 xjc 生成的Record.java类(减去注释):

@XmlAccessorType(XmlAccessType.FIELD)
@XmlType(name = "", propOrder = {"fooBar"})
@XmlRootElement(name = "record")
public class Record {
    @XmlElement(name = "foo-bar", required = true)
    protected String fooBar;
    public String getFooBar() {return fooBar;}
    public void setFooBar(String value) {this.fooBar = value;}
}

然后,尝试通过jxpath(实际上我必须处理许多深度嵌套的类)访问数据,可以在下面看到正确的 XPath ( "foo-bar") 不起作用,但骆驼大小写的版本可以。

    Record record = new Record();
    record.setFooBar("hello world");

    JXPathContext context = JXPathContext.newContext(record);
    context.setLenient(true);
    String a = (String)context.getValue("foo-bar", String.class);  // is null
    String b = (String)context.getValue("fooBar", String.class);  // "hello world"
4

1 回答 1

1

我相信 JXPath 对对象属性而不是它们对应的 XML 元素进行操作。我不相信 JXPath 会解析任何 JAXB 元数据,因此它不会知道您映射的 XML 节点。您所看到的似乎是预期的行为。

于 2015-03-15T12:53:21.003 回答