我尝试从服务器端请求获得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天访问令牌?
任何人都可以帮助我,因为我有点被人混淆了吗?
答案 0 :(得分:1)
我对自己的问题有部分答案。我试图收到我自己的扩展访问令牌(我是应用程序的所有者)所以Facebook没有给我扩展令牌,但是当我尝试其他一些时,我会收到常规的60天访问令牌。