Rumah >Java >javaTutorial >Bila hendak menggunakan XPath pada Dokumen XML dengan Ruang Nama Lalai?

Bila hendak menggunakan XPath pada Dokumen XML dengan Ruang Nama Lalai?

Mary-Kate Olsen
Mary-Kate Olsenasal
2024-10-24 06:57:421043semak imbas

When to Use XPath on XML Documents with a Default Namespace?

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!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn