Menggunakan XPath pada Dokumen XML dengan Ruang Nama Lalai
Apabila memanipulasi dokumen XML dengan ruang nama lalai dan tanpa awalan, anda boleh menggunakan XPath tanpa URI ruang nama, seolah-olah tiada ruang nama wujud. Walau bagaimanapun, menetapkan sifat namespaceAware DocumentBuilderFactory kepada palsu mungkin tidak selalu memadai.
Untuk berjaya menggunakan XPath pada dokumen tersebut, anda boleh menggunakan NamespaceContext apabila melaksanakan XPath. Ini melibatkan awalan serpihan XPath untuk dipadankan dengan NamespaceContext. Awalan yang digunakan tidak perlu diselaraskan dengan yang terdapat dalam dokumen.
Berikut ialah versi terkini kod anda yang menggabungkan pendekatan ini:
<code class="java">import java.util.Iterator; import javax.xml.namespace.NamespaceContext; import javax.xml.parsers.DocumentBuilder; import javax.xml.parsers.DocumentBuilderFactory; import javax.xml.xpath.XPath; import javax.xml.xpath.XPathConstants; import javax.xml.xpath.XPathFactory; import org.w3c.dom.Document; import org.w3c.dom.NodeList; public class Demo { public static void main(String[] args) { DocumentBuilderFactory domFactory = DocumentBuilderFactory.newInstance(); domFactory.setNamespaceAware(true); try { DocumentBuilder builder = domFactory.newDocumentBuilder(); Document dDoc = builder.parse("E:/test.xml"); XPath xPath = XPathFactory.newInstance().newXPath(); xPath.setNamespaceContext(new MyNamespaceContext()); NodeList nl = (NodeList) xPath.evaluate("/ns:root/ns:author", dDoc, XPathConstants.NODESET); System.out.println(nl.getLength()); } catch (Exception e) { e.printStackTrace(); } } private static class MyNamespaceContext implements NamespaceContext { public String getNamespaceURI(String prefix) { if("ns".equals(prefix)) { return "http://www.mydomain.com/schema"; } return null; } public String getPrefix(String namespaceURI) { return null; } public Iterator getPrefixes(String namespaceURI) { return null; } } }</code>
Perhatikan bahawa ungkapan XPath juga telah diperbetulkan , mengikut cadangan Dennis.
Sebagai alternatif, coretan kod ringkas berikut juga boleh berfungsi:
<code class="java">import javax.xml.parsers.DocumentBuilder; import javax.xml.parsers.DocumentBuilderFactory; import javax.xml.xpath.XPath; import javax.xml.xpath.XPathConstants; import javax.xml.xpath.XPathFactory; import org.w3c.dom.Document; import org.w3c.dom.NodeList; public class Demo { public static void main(String[] args) { DocumentBuilderFactory domFactory = DocumentBuilderFactory.newInstance(); try { DocumentBuilder builder = domFactory.newDocumentBuilder(); Document dDoc = builder.parse("E:/test.xml"); XPath xPath = XPathFactory.newInstance().newXPath(); NodeList nl = (NodeList) xPath.evaluate("/root/author", dDoc, XPathConstants.NODESET); System.out.println(nl.getLength()); } catch (Exception e) { e.printStackTrace(); } } }</code>
Atas ialah kandungan terperinci Bila hendak menggunakan XPath pada Dokumen XML dengan Ruang Nama Lalai?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!