2.0版本之后的Facebook将不再支持FQL。 所以我要改为从FQL改为图api。
我的旧FQL代码是..
SELECT source_id,post_id,message,like_info.like_count,comment_info.comment_count,share_info.share_count,permalink,created_time,attachment.media FROM stream WHERE source_id = "--page_id--" AND actor_id = "--page_id--" AND created_time>--time_start-- AND created_time<--time_end-- ORDER BY like_info.like_count DESC
这是我使用phpsdk4的图形api代码,它从上面的fql代码传输并且它不完整(因为我不知道下一步该怎么做)。
require_once 'facebookphpsdk4/autoload.php';
use Facebook\FacebookSession;
use Facebook\FacebookRedirectLoginHelper;
use Facebook\FacebookRequest;
use Facebook\FacebookResponse;
use Facebook\FacebookSDKException;
use Facebook\FacebookRequestException;
use Facebook\FacebookAuthorizationException;
use Facebook\GraphObject;
use Facebook\Entities\AccessToken;
use Facebook\HttpClients\FacebookCurlHttpClient;
use Facebook\HttpClients\FacebookHttpable;
$access_token = 'xxx|yyy';
FacebookSession::setDefaultApplication( 'xxx','yyy' );
$session = new FacebookSession($access_token);
$request = new FacebookRequest(
$session,
'GET',
'/page_id?fields=posts{id,shares,message,likes.summary(true),comments.summary(true)}'
);
$response = $request->execute();
$graphObject = $response->getGraphObject()->asArray();
我需要......
如何在不使用fql的情况下获得所有这些? 谢谢你的回答。
答案 0 :(得分:1)
使用Graph API而不是FQL获得相同结果有几个问题:
permalink
字段attachments
为大created_time
但要指定时间过滤器,您可以使用网址参数since
和until
:
GET /{page_id}/posts?fields=id,message,shares,object_id,likes.summary(true),comments.summary(true),attachments{media}&since=1423440000&until=1423526399
这应该是您今天发布的特定页面的所有帖子。
您可以通过连接imho创建permalink
:
https://www.facebook.com/{page_id}/posts/{object_id}
请参阅: