Php 从Facebook页面获取手动RSS提要-我是否遗漏了什么?
我试图从客户的Facebook页面获取RSS提要,修改内容(帖子),编辑并在他们的网站上呈现结果数据。我不想使用来自第三方的小部件,也不想使用Facebook API,因为它们不允许我访问原始数据 我以前接受过feed,我提供的代码在NBC、谷歌等网站上运行得非常好,但我从Facebook上什么也得不到。我正在使用的URL在浏览器中运行良好,但在我的代码中不起作用,我希望这里的人能够指出我毫无疑问的明显错误Php 从Facebook页面获取手动RSS提要-我是否遗漏了什么?,php,facebook,rss,Php,Facebook,Rss,我试图从客户的Facebook页面获取RSS提要,修改内容(帖子),编辑并在他们的网站上呈现结果数据。我不想使用来自第三方的小部件,也不想使用Facebook API,因为它们不允许我访问原始数据 我以前接受过feed,我提供的代码在NBC、谷歌等网站上运行得非常好,但我从Facebook上什么也得不到。我正在使用的URL在浏览器中运行良好,但在我的代码中不起作用,我希望这里的人能够指出我毫无疑问的明显错误 $xml=("<http://www.facebook.com/feeds/pag
$xml=("<http://www.facebook.com/feeds/page.php?id=xxxxxxxxxxxxxx&format=rss20>")
$xmlDoc = new DOMDocument();
$xmlDoc->load($xml);
//get elements from "<channel>"
$channel=$xmlDoc->getElementsByTagName('channel')->item(0);
$channel_title = $channel->getElementsByTagName('title')
->item(0)->childNodes->item(0)->nodeValue;
$channel_link = $channel->getElementsByTagName('link')
->item(0)->childNodes->item(0)->nodeValue;
$channel_desc = $channel->getElementsByTagName('description')
->item(0)->childNodes->item(0)->nodeValue;
//output elements from "<channel>"
echo("<p><a href='" . $channel_link
. "'>" . $channel_title . "</a>");
echo("<br>");
echo($channel_desc . "</p>");
//get and output "<item>" elements
$x=$xmlDoc->getElementsByTagName('item');
for ($i=0; $i<=2; $i++) {
$item_title=$x->item($i)->getElementsByTagName('title')
->item(0)->childNodes->item(0)->nodeValue;
$item_link=$x->item($i)->getElementsByTagName('link')
->item(0)->childNodes->item(0)->nodeValue;
$item_desc=$x->item($i)->getElementsByTagName('description')
->item(0)->childNodes->item(0)->nodeValue;
echo ("<p><a href='" . $item_link
. "'>" . $item_title . "</a>");
echo ("<br>");
echo ($item_desc . "</p>");
}
$xml=(“”)
$xmlDoc=新的DOMDocument();
$xmlDoc->load($xml);
//从“”获取元素
$channel=$xmlDoc->getElementsByTagName('channel')->项(0);
$channel\u title=$channel->getElementsByTagName('title'))
->项(0)->子节点->项(0)->节点值;
$channel\u link=$channel->getElementsByTagName('link'))
->项(0)->子节点->项(0)->节点值;
$channel\u desc=$channel->getElementsByTagName('description'))
->项(0)->子节点->项(0)->节点值;
//从“”输出元素
回声();
回声(
);
回声($channel_desc.“”);
//获取并输出“”元素
$x=$xmlDoc->getElementsByTagName('item');
对于($i=0;$iitem($i)->getElementsByTagName('title'))
->项(0)->子节点->项(0)->节点值;
$item\u link=$x->item($i)->getElementsByTagName('link'))
->项(0)->子节点->项(0)->节点值;
$item_desc=$x->item($i)->getElementsByTagName('description'))
->项(0)->子节点->项(0)->节点值;
回声();
回声(
);
回声($item_desc.“”);
}
如果您只是在做一些非常简单的事情,那么可以使用它,这与DOM之间有一些区别,您可以阅读更多相关内容
下面是一个使用simplexml\u load\u文件的代码示例:
<?php
/**
* Facebook Page Feed Parser
*/
function fb_parse_feed( $page_id, $no = 5 ) {
// You need to query the feed as a browser.
ini_set('user_agent', 'Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.8.1.9) Gecko/20071025 Firefox/2.0.0.9');
// Facebook Page id
$page_id = 'xxxxxxxxxxxxxxx';
// URL to the Facebook page's RSS feed.
$rss_url = 'http://www.facebook.com/feeds/page.php?id=' . $page_id . '&format=rss20';
$xml = simplexml_load_file( $rss_url );
$out = '';
$i = 1;
foreach( $xml->channel->item as $item ){
$out .= '<div class="entry">';
$out .= '<h3 class="title"><a href="' . $item->link . '">' . $item->title . '</a></h3>';
$out .= '<div class="meta">' . $item->pubDate . ' by '. $item->author .'</div>';
$out .= '<div class="content">' . $item->description . '</div></div>';
if( $i == $no ) break;
$i++;
}
echo $out;
}
// This will print the above
fb_parse_feed();
?>
那么什么不起作用呢?请确保这样做不会违反Facebook的服务条款。他们可能正是出于这个原因阻止了这种方法。您是否至少尝试了一些非常基本的调试步骤来查看错误发生的位置?您是否将PHP的错误报告设置为合理的开发值?谢谢合作mments伙计们…WizKid->我从提要中没有内容,没有数据。CBroe->没有错误,代码在其他来源上运行得非常好-我只是从FB得到一个空白。Mike Lyons->你可能是对的,但为什么第三方小部件可以工作?M.Doye->感谢代码,但这并没有更好。