Php 从Facebook页面获取手动RSS提要-我是否遗漏了什么?

Php 从Facebook页面获取手动RSS提要-我是否遗漏了什么?,php,facebook,rss,Php,Facebook,Rss,我试图从客户的Facebook页面获取RSS提要,修改内容(帖子),编辑并在他们的网站上呈现结果数据。我不想使用来自第三方的小部件,也不想使用Facebook API,因为它们不允许我访问原始数据 我以前接受过feed,我提供的代码在NBC、谷歌等网站上运行得非常好,但我从Facebook上什么也得不到。我正在使用的URL在浏览器中运行良好,但在我的代码中不起作用,我希望这里的人能够指出我毫无疑问的明显错误 $xml=("<http://www.facebook.com/feeds/pag

我试图从客户的Facebook页面获取RSS提要,修改内容(帖子),编辑并在他们的网站上呈现结果数据。我不想使用来自第三方的小部件,也不想使用Facebook API,因为它们不允许我访问原始数据

我以前接受过feed,我提供的代码在NBC、谷歌等网站上运行得非常好,但我从Facebook上什么也得不到。我正在使用的URL在浏览器中运行良好,但在我的代码中不起作用,我希望这里的人能够指出我毫无疑问的明显错误

$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->感谢代码,但这并没有更好。