我正在尝试在PHP中阅读一些带有DOM的RSS提要,如下所示:
<channel>
<atom:link href='' rel='self' type='application/rss+xml' />
<title>TechStuff</title>
<link>http://www.howstuffworks.com</link>
要获取链接(<link></link>
),我使用这段代码:
$doc->getElementsByTagName('link')->item(0);
它适用于我尝试过的所有其他 RSS 提要。但是这个把<atom:link>
放在<link>
之前,这意味着它抓住了<atom:link>
。
那么我该怎么做才能只选择没有命名空间的节点呢?
设法
通过使用DOMXPath和XPath语法来解决它。
下面是 DOMXPath 示例:
$xpath = new DOMXpath($doc);
$linkPath = $xpath->query("/rss/channel/link");
$link = $linkPath->item(0)->nodeValue;
在类似的XML层次结构上,它对我有用。
您可以通过
检查->prefix
或->namespaceURI
来判断节点是否具有命名空间:
foreach ($doc->getElementsByTagName('link') as $link) {
if (strlen($link->prefix)) {
continue;
}
// $link does not have prefix
}