기본 네임스페이스가 있는 XML 문서에 XPath 사용
기본 네임스페이스가 있는 XML 문서로 작업할 때 XPath 표현식을 활용하는 것이 어려워 보일 수 있습니다. 네임스페이스 URI를 명시적으로 선언하지 않고. 그러나 이 상황을 해결하는 접근 방식이 있습니다.
Namespace Awareness를 False로 설정
원래 질문에서 언급했듯이 초기 이해는 네임스페이스 Aware를 false로 설정하는 것이었습니다. DocumentBuilderFactory를 사용하면 네임스페이스 URI를 사용하여 작업할 필요가 없습니다. 그러나 이 접근 방식은 기본 네임스페이스가 있는 문서에는 적합하지 않습니다. 기본 네임스페이스에는 명시적인 처리가 필요합니다.
NamespaceContext 활용
대체 솔루션은 XPath 실행 중에 NamespaceContext를 사용하는 것입니다. 이를 통해 XPath 표현식 내의 네임스페이스와 접두사를 연결할 수 있습니다. 사용되는 접두사는 XML 문서에 정의된 접두사와 다를 수 있습니다.
다음은 이 접근 방식을 구현하는 예입니다.
<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>
이 예에서 제공된 NamespaceContext는 'ns' 접두사를 다음에 매핑합니다. XML 문서에 사용된 네임스페이스 URI.
수정된 XPath 표현식
Dennis는 원래 XPath 표현식 "/root/author"가 잘못되었음을 올바르게 지적합니다. 기본 네임스페이스가 있는 문서의 경우 올바른 표현은 "/ns:root/ns:author"여야 합니다. 이는 코드에 새로 도입된 네임스페이스 접두사와 일치합니다.
네임스페이스 인식을 통한 단순화
흥미롭게도 네임스페이스Aware를 true로 설정하고 NamespaceContext를 생략하면 원하는 결과. 이는 다음 코드에서 설명됩니다.
<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>
이 경우 문서의 네임스페이스가 처리 중에 인식되고 암시되므로 익숙한 XPath 표현식 "/root/author"를 사용할 수 있습니다.
위 내용은 XPath를 사용하여 기본 네임스페이스가 있는 XML 문서를 처리하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!