0

在我的应用高级设置中启用了删除 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 ) );

并将页面令牌保存在我的数据库中。当我稍后尝试使用这些令牌时,我收到一条回复说令牌已过期。

有人知道我的问题是什么吗?

4

1 回答 1

0

我遇到了同样的问题并在这里找到了解决方案-使用 setExtendedAccessToken() 获取长期访问令牌返回短期令牌

// 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

于 2013-05-16T23:08:45.777 回答