您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

自offline_access弃用以来如何扩展访问令牌的有效性

自offline_access弃用以来如何扩展访问令牌的有效性

一周前,官方的Facebook PHP SDK也已更新。函数名称已更改为 setExtendedAccessToken ,并确定我们实际上随后需要销毁该会话,以消除拥有两个活动会话的风险。 同样,该函数不再实际返回令牌,而是将其存储在持久性数据中。因此,您之后可以使用公共函数 getAccessToken 获取新的访问令牌。从官方的Facebook PHP SDK github页面获取新的SDK,以确保您是最新的。

我在base_facebook.PHP文件添加一个新的公共函数,该函数返回一个新的访问令牌,该令牌将在60天后过期。收到正常的访问令牌后,您可以请求此功能。我尚未测试,但我想您还需要在开发人员应用的“高级”设置中启用“不赞成使用离线访问”。

只需将其添加到facebook类内的base_facebook.PHP中,然后对其进行调用。这个对我有用。

 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'), array(
                    'client_id' => $this->getAppId(),
                    'client_secret' => $this->getAppSecret(),
                    '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'];
}
Access 2022/1/1 18:13:38 有669人围观

撰写回答


你尚未登录,登录后可以

和开发者交流问题的细节

关注并接收问题和回答的更新提醒

参与内容的编辑和改进,让解决方法与时俱进

请先登录

推荐问题


联系我
置顶