Problème :
Avec la dépréciation de l'autorisation d'accès hors ligne dans le flux d'authentification de Facebook , récupérer des jetons d'accès de longue durée sans cette autorisation est devenu un défi. Malgré la documentation de Facebook indiquant que les jetons OAuth côté serveur auront une longue durée de vie, ce n'est pas le cas.
Solution :
Facebook a mis à jour le SDK PHP pour inclure une méthode pour prolonger la validité du jeton d'accès.
SDK mis à jour Méthode :
Une fonction publique nommée setExtendedAccessToken a été ajoutée à base_facebook.php. Cette fonction renvoie un nouveau jeton d'accès avec une expiration de 60 jours.
Utilisation :
Appelez cette fonction après avoir reçu le jeton d'accès normal. Vous pouvez accéder au nouveau jeton à l'aide de la fonction publique getAccessToken.
Fonction de jeton d'accès étendu :
public function getExtendedAccessToken(){ try { $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) { 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']; }
Remarque :
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!