删除我的应用高级设置中的offline_access权限;
我首先调用以下函数:
public function app_login( $url_redirect=null ) {
$facebook = new Facebook(array(
'appId' => APP_ID,
'secret' => APP_SECRET,
'cookie' => true,
'fileUpload' => true
));
//check if redirection url specified
if( $url_redirect != null )
$go_to = $url_redirect;
else
$go_to = 'APP_URL';
$loginParams = array(
'scope' => 'publish_stream,user_activities,user_checkins,user_interests,user_location,manage_pages,email,read_insights,read_stream',
'redirect_uri' => $go_to
);
$login_url = $facebook->getLoginUrl( $loginParams );
if ( ! $facebook->getUser() ) {
echo '<script>window.top.location = "' . $login_url . '";</script>';
return true;
}
return $facebook;
}
返回名为$ facebook的值, 然后我通过以下调用请求扩展用户令牌:
$facebook->setExtendedAccessToken();
$extended_token = $facebook->getAccessToken();
在我的数据库中保存$ extended_token,然后使用
获取用户页面$pages = @json_decode( FB_Actions::file_get_contents_curl( 'https://graph.facebook.com/' . $facebook->getUser() . '/accounts?access_token=' . $extended_token ) );
并在我的数据库中保存页面标记。 当我稍后尝试使用这些令牌时,我得到一个回复说该令牌已过期。
有人知道我的问题是什么吗?
答案 0 :(得分:0)
我遇到了同样的问题并在此处找到了解决方案 - Getting long-lived access token with setExtendedAccessToken() returns short lived token
// ask for the extended token and get it from session ...
$facebook->setExtendedAccessToken();
$access_token = $_SESSION["fb_".FB_APP_ID."_access_token"];
// now set it into the facebook object ....
$facebook->setAccessToken($access_token);
// now our fb object will use the new token as usual ...
$accessToken = $facebook->getAccessToken();
还可以使用facebook调试工具 - https://developers.facebook.com/tools/debug