2010-05-12 11 views
5

Können Sie mir helfen, diesen Code anzupassen, damit er das XML parsen kann? Wenn ich das XML-Namespace Drop funktioniert es:XML mit XPath & Namespaces in Java analysieren

String webXmlContent = "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n" + 
         "<foo xmlns=\"http://foo.bar/boo\"><bar>baz</bar></foo>"; 
DocumentBuilderFactory domFactory = DocumentBuilderFactory.newInstance(); 
domFactory.setNamespaceAware(true); 
DocumentBuilder builder = domFactory.newDocumentBuilder(); 
org.w3c.dom.Document doc = builder.parse(new StringInputStream(webXmlContent)); 

NamespaceContextImpl namespaceContext = new NamespaceContextImpl(); 
namespaceContext.startPrefixMapping("foo", "http://www.w3.org/2001/XMLSchema-instance"); 
XPath xpath = XPathFactory.newInstance().newXPath(); 
xpath.setNamespaceContext(namespaceContext); 

XPathExpression expr = xpath.compile("/foo/bar"); 
Object result = expr.evaluate(doc, XPathConstants.NODESET); 
NodeList nodes = (NodeList) result; 
System.out.println("Got " + nodes.getLength() + " nodes"); 

Antwort

9
  1. Sie einen Präfix in Ihrem XPath verwenden müssen, e. g .: "/ my: foo/my: bar" Sie können ein beliebiges Präfix auswählen - es hat nichts mit den Präfixen zu tun, die Sie verwenden oder nicht in der XML-Datei verwenden - aber Sie müssen eine auswählen. Dies ist eine Einschränkung von XPath 1.0.

  2. Sie müssen Präfix Zuordnung von "mein" auf "http://foo.bar/boo" (nicht auf "http://www.w3.org/2001/XMLSchema-instance")

+0

Danke, wirkt wie ein Zauber auszuführen. – ripper234