我开始使用xml.jcabi xml库。它看起来像一个简单的库,但如果设置了xmlns名称空间,我无法查询节点。
这是我的xml文件:
<MyRequestData xmlns='http://www.myaddress.com/myfile.xsd' xmlns:xsi='http://www.w3.org/2001/XMLSchema-instance'>
<RequestData>
<startDate>2016-03-25</startDate>
<endDate>2016-03-25</endDate>
</RequestData>
</MyRequestData>
我的Java代码如下所示:
XML xmlRequest = new XMLDocument(requestFileIS);
xmlRequest.registerNs("xmlns", "http://www.myaddress.com/myfile.xsd");
for (XML requestData : xmlAdHocRequest.nodes("//xmlns:RequestData"))
{
String startDate = requestData.xpath("startDate/text()").get(0);
}
我的问题是xmlAdHocRequest.nodes("//xmlns:RequestData")
返回零节点。如果我从XML文件中删除默认命名空间(显然)从NS寄存器中删除,而不是查询工作。
我还尝试通过将其前缀设置为m而不是xmlns来注册xmlns(默认)命名空间:
XML xmlAdHocRequest = new XMLDocument(requestFileIS);
xmlRequest.registerNs("m", "http://www.myaddress.com/myfile.xsd");
for (XML requestData : xmlRequest.nodes("//m:RequestData")) {
String startDate = requestData.xpath("startDate/text()").get(0);
}
当我尝试获取节点时,我只收到错误:
java.lang.IllegalArgumentException: invalid XPath query '//x:RequestData' by org.apache.xpath.jaxp.XPathFactoryImpl
at org.apache.xpath.compiler.XPathParser.errorForDOM3(XPathParser.java:655)
at org.apache.xpath.compiler.Lexer.mapNSTokens(Lexer.java:647)
at org.apache.xpath.compiler.Lexer.tokenize(Lexer.java:365)
at org.apache.xpath.compiler.Lexer.tokenize(Lexer.java:98)
at org.apache.xpath.compiler.XPathParser.initXPath(XPathParser.java:112)
at org.apache.xpath.XPath.<init>(XPath.java:178)
at org.apache.xpath.XPath.<init>(XPath.java:266)
at org.apache.xpath.jaxp.XPathImpl.eval(XPathImpl.java:195)
at org.apache.xpath.jaxp.XPathImpl.evaluate(XPathImpl.java:281)
at com.jcabi.xml.XMLDocument.fetch(XMLDocument.java:429)
at com.jcabi.xml.XMLDocument.nodes(XMLDocument.java:352)
我的问题是:我做错了什么或是某种xml.jcabi问题?
答案 0 :(得分:0)
定义名称空间前缀(xmlns=
定义默认名称空间 - 而不是名称空间前缀),然后在XPath中使用它。
...具体
更改
xmlRequest.registerNs("xmlns", "http://www.myaddress.com/myfile.xsd");
到
xmlRequest.registerNs("m", "http://www.myaddress.com/myfile.xsd");
更改
//xmlns:RequestData
到
//m:RequestData