繁体   English   中英

DOMXPath-获取节点

[英]DOMXPath - Get Node

我面临一个无法解决的问题。 我正在使用DOMXPath来检索以下XML文件的MsgId标记的值:

<?xml version="1.0" encoding="UTF-8"?>
<Document xmlns="urn:iso:std:iso:20022:tech:xsd:pain.001.001.03" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
    <CstmrCdtTrfInitn>
        <GrpHdr>
            <MsgId>Test/20171013/CCT100621</MsgId>
            <CreDtTm>2017-10-13T10:06:21</CreDtTm>
            <NbOfTxs>62</NbOfTxs>
        </GrpHdr>
    </CstmrCdtTrfInitn>
</Document>

以下是我用DOMXPath查询XML的PHP​​代码段:

$xml = <<<XML
    <?xml version="1.0" encoding="UTF-8"?>
    <Document xmlns="urn:iso:std:iso:20022:tech:xsd:pain.001.001.03" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
        <CstmrCdtTrfInitn>
            <GrpHdr>
                <MsgId>Test/20171013/CCT100621</MsgId>
                <CreDtTm>2017-10-13T10:06:21</CreDtTm>
                <NbOfTxs>62</NbOfTxs>
            </GrpHdr>
        </CstmrCdtTrfInitn>
    </Document>
XML;

$document = new DOMDocument;
$document->loadXML($xml);
$groupHeaderXPath = new DOMXPath($document);
echo $groupHeaderXPath->query('//GrpHdr/MsgId')->length; // returns 0

我正在使用此工具测试查询,看来它是正确的。

有谁知道为什么xpath表达式在这种情况下不起作用? 我在这里错过了一些细节吗?

$groupHeaderXPath是类型的DOMXPath ,其具有方法registerNamespace

我认为这将有助于注册名称空间并在xpath表达式中使用前缀“ urn”。

例如:

$rootNamespace = $document->lookupNamespaceUri($document->namespaceURI);
$groupHeaderXPath->registerNamespace("urn", $rootNamespace);
echo $groupHeaderXPath->query('//urn:GrpHdr/urn:MsgId')->length; // returns 1

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM