如何通过facebook graph api获取组的所有帖子

时间:2013-02-17 09:31:38

标签: facebook facebook-graph-api

我想从facebook组中获取所有帖子并参考其ID。我试过这个:

https://graph.facebook.com/".$group_id."/feed?time_format=U&".$authToken

只给了我一些帖子。如果可能的话,我希望所有帖子都由一个网址检索,如果不是通过分页网址。但是分页URL包含分页标记

https://graph.facebook.com/55259308085/feed?limit=500&access_token=ACCESS_TOKEN&until=1298025645&__paging_token=55259308085_10150259582898086

什么是分页令牌和直到??

请指引我走正确的道路。 谢谢。

3 个答案:

答案 0 :(得分:16)

set_time_limit(99999999);
ini_set('memory_limit', "9999M");

function fetchUrl($url) {
    $ch = curl_init();
    curl_setopt($ch, CURLOPT_URL, $url);
    curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 0);
    curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, 0);
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
    curl_setopt($ch, CURLOPT_TIMEOUT, 40);

    $data = curl_exec($ch);
    curl_close($ch);

    return $data;
}

$url_array = array();

function recurse_it($url, $c) {
    global $url_array;
    $feeds         = fetchUrl($url);
    $feed_data_obj = json_decode($feeds, true);
    if (!empty($feed_data_obj['data'])) {
        $next_url      = $feed_data_obj['paging']['next'];
        $url_array[$c] = $next_url;
        recurse_it($next_url, $c + 1);
    }
    return $url_array;
}

$url = "https://graph.facebook.com/55259308085/groups?access_token=xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx";
$arr = recurse_it($url, 0);
print_r($arr);

其中$arr是所有可用分页链接的数组,我使用foreach循环遍历分页的所有内容。
如果需要,我可以提供更多解释。

答案 1 :(得分:9)

在PHP中尝试:

$response = file_get_contents("https://graph.facebook.com/$group_id/feed?limit=1000&access_token=$access_token");

它会为您提供一个限制为1000个帖子的页面。将JSON响应转换为PHP关联数组:

$array = json_decode($response, true);
// Do your own stuff with $array ...

获取下一页:

$response = file_get_contents($array['paging']['next']);

在循环中尝试此操作,直到$array['data']在响应中显示为空。


直到 - 这是一个UNIX时间整数,用于指定要获取帖子的时间点(仅显示之后发布的帖子)。

答案 2 :(得分:2)

$url_array=array();
$url="https://graph.facebook.com/v2.2/".$fbpageid."/feed?access_token=".$access_token."&limit=250&fields=full_picture,picture,id,message,name,caption,description,updated_time,link,icon,from,privacy,type,status_type,application,object_id,story,story_tags,actions";

function recurse_it($url,$c)
{
    $feeds=file_get_contents($url);
    $feed_data_obj=json_decode($feeds,true);
    while(!empty($feed_data_obj['data']))
    {   
        $next_url      = $feed_data_obj['paging']['next'];
        $url_array[$c] = $next_url;
        $feeds=file_get_contents($next_url);
        $feed_data_obj=json_decode($feeds,true);
        $c=$c+1;
    }
    return $url_array;
}
$final_result=recurse_it($url,0);