Facebook扩展访问令牌不起作用 - 但一切似乎都很好(?)

时间:2012-04-12 09:15:50

标签: php facebook oauth-2.0 access-token

我尝试从服务器端请求获得60天的facebook访问令牌。在用户进入后,我通过Facebook SDK中的getAccessToken()函数检查访问令牌,之后我使用了我在这里找到的getExtendedAccessToken():How to extend access token validity since offline_access deprecation要求60天访问令牌:

   public function getExtendedAccessToken() {

        try {
        // need to circumvent json_decode by calling _oauthRequest
        // directly, since response isn't JSON format.
        $access_token_response =
            $this->_oauthRequest(
                $this->getUrl('graph', '/oauth/access_token'),
                    $params = array(    'client_id' => $this->getAppId(),
                                'client_secret' => $this->getApiSecret(),
                                'grant_type'=>'fb_exchange_token',
                                'fb_exchange_token'=>$this->getAccessToken(),
                 ));

        } catch (FacebookApiException $e) {
        // most likely that user very recently revoked authorization.
        // In any event, we don't have an access token, so say so.
              return false;
        }

        if (empty($access_token_response)) {
             return false;
        }

        $response_params = array();
        parse_str($access_token_response, $response_params);
        if (!isset($response_params['access_token'])) {
            return false;
        }

        return $response_params['access_token'];
        }

不幸的是,我的访问令牌在2小时后仍然无效,所以我也尝试了这个:

    public function getSimpleExtendedAccessToken(){

    $request = 'https://graph.facebook.com/oauth/access_token?
                client_id='. $this->getAppId(). 
                '&client_secret=' .$this->getApiSecret(). 
                '&grant_type=fb_exchange_token
                &fb_exchange_token=' .$this->getAccessToken();

    $response = file_get_contents($request);
    $params = null;
    parse_str($response, $params);
    return $params['access_token'];
}

这个也在2小时后过期了。但当我在第二个函数中检查数组$params内的内容时,写了:

  

数组([access_token] => AAAFM5sO7 [...] [expires] => 4897)

(那部分:“AAAFM5sO7[...]”当然是我的访问令牌号码)

我收到的所有访问令都是相同的:第一个来自getAccessToken(),第二个来自getExtendedAccessToken(),第三个来自getSimpleExtendedAccessToken()

当然,当我越来越多地要求addtionaly扩展访问令牌时,到期号码不会更新,但它会倒计时,从Facebook文档的角度来看这是正确的,因为你不能要求新的每分钟访问令牌,但为什么我不能获得60天访问令牌?

任何人都可以帮助我,因为我有点被人混淆了吗?

1 个答案:

答案 0 :(得分:1)

我对自己的问题有部分答案。我试图收到我自己的扩展访问令牌(我是应用程序的所有者)所以Facebook没有给我扩展令牌,但是当我尝试其他一些时,我会收到常规的60天访问令牌。