Menggunakan XPath untuk Dokumen XML dengan Ruang Nama Lalai
Apabila bekerja dengan dokumen XML yang menampilkan ruang nama lalai, ia mungkin kelihatan mencabar untuk menggunakan ungkapan XPath tanpa mengisytiharkan URI ruang nama secara eksplisit. Walau bagaimanapun, terdapat pendekatan untuk menangani situasi ini.
Menetapkan Kesedaran Ruang Nama kepada Palsu
Seperti yang dinyatakan dalam soalan asal, pemahaman awal ialah menetapkan namespaceAware kepada false dalam DocumentBuilderFactory akan menghapuskan keperluan untuk bekerja dengan URI ruang nama. Walau bagaimanapun, pendekatan ini tidak sesuai untuk dokumen dengan ruang nama lalai. Ruang nama lalai memerlukan pengendalian eksplisit.
Menggunakan NamespaceContext
Penyelesaian alternatif melibatkan penggunaan NamespaceContext semasa pelaksanaan XPath. Ini membolehkan anda mengaitkan awalan dengan ruang nama dalam ungkapan XPath. Awalan yang digunakan boleh berbeza daripada yang ditakrifkan dalam dokumen XML.
Berikut ialah contoh yang melaksanakan pendekatan ini:
<code class="java">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>
Dalam contoh ini, NamespaceContext yang disediakan memetakan awalan 'ns' kepada URI ruang nama yang digunakan dalam dokumen XML.
Ungkapan XPath yang disemak
Dennis betul-betul menunjukkan bahawa ungkapan XPath asal "/root/author" adalah tidak betul. Untuk dokumen dengan ruang nama lalai, ungkapan yang betul hendaklah "/ns:root/ns:author". Ini sejajar dengan awalan ruang nama yang baru diperkenalkan dalam kod.
Pemudahan dengan Kesedaran Ruang Nama
Menariknya, nampaknya menetapkan namespaceAware kepada benar dan mengabaikan NamespaceContext juga menyediakan hasil yang diingini. Ini ditunjukkan dalam kod berikut:
<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(); domFactory.setNamespaceAware(true); 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>
Dalam kes ini, ungkapan XPath biasa "/root/author" boleh digunakan, kerana ruang nama dokumen dikenali dan tersirat semasa pemprosesan.
Atas ialah kandungan terperinci Bagaimana Mengendalikan Dokumen XML dengan Ruang Nama Lalai Menggunakan XPath?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!