这就是我在PHP中所做的,以便访问Facebook上的一堆群帖。我正在实施搜索功能来搜索这些帖子。
$url2 = 'https://graph.facebook.com/'. $group_id . '/feed' . '?limit=30&access_token=' . $_SESSION['access_token'] ;
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, "$url2");
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
$json = curl_exec($ch);
$data = json_decode($json, TRUE);
所以我将其分解并发现将图形URL放入浏览器会产生缓慢的响应。限制设置为30是可以的,但是它增加到300并且它很慢,达到1,000并且它会爬行。
我看过分页,但我想抓取大量数据,以便我可以搜索它。缓存真的不起作用,因为加载初始数据仍然需要很长时间。
有没有提高速度,还是我坚持使用Facebook Graph API的限制?
答案 0 :(得分:7)
您可以批量处理您的请求,这样您只需为批量处理的请求设置一次卷曲,而不是查看多个卷曲http://developers.facebook.com/blog/post/2011/03/17/batch-requests-in-graph-api/
$app_id = "YOUR_APP_ID";
$app_secret = "YOUR_APP_SECRET";
$my_url = "YOUR_URL";
$code = $_REQUEST["code"];
if(empty($code)) {
$dialog_url = "http://www.facebook.com/dialog/oauth?client_id=" . $app_id . "&redirect_uri=" . urlencode($my_url);
echo("<script> top.location.href='" . $dialog_url . "'</script>");
}
$token_url = "https://graph.facebook.com/oauth/access_token?client_id=" . $app_id . "&redirect_uri=" . urlencode($my_url) . "&client_secret=" . $app_secret . "&code=" . $code;
$access_token = file_get_contents($token_url);
$batched_request = '[{"method":"GET","relative_url":"me"},' . '{"method":"GET","relative_url":"me/friends?limit=50"}]';
$post_url = "https://graph.facebook.com/" . "?batch=" . $batched_request . "&access_token=" . $access_token . "&method=post";
echo $post_url;
$post = file_get_contents($post_url);
echo '<p>Response: <pre>' . $post . '</pre></p>';
答案 1 :(得分:1)
您可以根据文档使用CURLOPT_ENCODING
:
“Accept-Encoding:”标题的内容。这使得能够解码 的回应。支持的编码是“身份”,“缩小”和 “压缩”。如果设置了空字符串“”,则包含全部的标题 发送支持的编码类型。
这样cURL会告诉Facebook,“嘿我理解压缩数据,请发给我压缩数据”。
$url2 = 'https://graph.facebook.com/'. $group_id . '/feed' . '?limit=30&access_token=' . $_SESSION['access_token'] ;
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $url2);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch, CURLOPT_ENCODING, ''); // enable compression, keep empty to send all supported types
$json = curl_exec($ch);
$data = json_decode($json, TRUE);