Maison > développement back-end > tutoriel php > Comment résoudre les erreurs « invalid_grant » lors de l'actualisation des jetons avec l'API Google Analytics ?

Comment résoudre les erreurs « invalid_grant » lors de l'actualisation des jetons avec l'API Google Analytics ?

Linda Hamilton
Libérer: 2024-12-08 14:02:11
original
221 Les gens l'ont consulté

How to Resolve

Jeton d'actualisation avec le client API Google

En utilisant l'API Google Analytics (V3), les utilisateurs peuvent rencontrer des erreurs, en particulier lorsqu'ils tentent de récupérer données provenant de comptes autres que leur compte de test. Ce problème se manifeste généralement par une erreur 403. De plus, même après avoir révoqué et réauthentifié le jeton, le problème peut réapparaître à l'expiration du jeton.

Pour résoudre ce problème, la solution réside dans l'utilisation de la méthode rafraîchirToken pour obtenir un nouveau jeton d'authentification. Cependant, l'exécution de $client->refreshToken(refresh_token_key) peut produire un message d'erreur d'octroi non valide ("error" : "invalid_grant").

En examinant le code derrière la méthode rafraîchirToken, il devient évident que ce qui suit les paramètres sont envoyés correctement :

  • client_id
  • client_secret
  • refresh_token
  • grant_type (codé en dur en tant quefresh_token)

Le la procédure de rafraîchissement du jeton est la suivante suit :

$client = new apiClient();
$client->setClientId($config['oauth2_client_id']);
$client->setClientSecret($config['oauth2_client_secret']);
$client->setRedirectUri($config['oauth2_redirect_uri']);
$client->setScopes('https://www.googleapis.com/auth/analytics.readonly');
$client->setState('offline');

$client->setAccessToken($config['token']); // The access JSON object.

$client->refreshToken($config['refreshToken']); // Will return error here
Copier après la connexion

La clé pour résoudre le problème est de comprendre que ce jeton initial obtenu lors de l'authentification possède un jeton d'actualisation. Bien que le jeton initial expire dans l’heure, le jeton d’actualisation peut être exploité pour obtenir un nouveau jeton. Cependant, il est crucial de noter que ce jeton temporaire expire également après une heure et n'est pas associé à un jeton d'actualisation. Par conséquent, pour récupérer un nouveau jeton temporaire, le jeton d'actualisation du jeton initial doit être utilisé.

Pour plus de clarté, le code suivant fournit une explication détaillée :

// Retrieve original token from database
$tokenquery = "SELECT * FROM token WHERE type='original'";
$tokenresult = mysqli_query($cxn, $tokenquery);
if ($tokenresult != 0) {
    $tokenrow = mysqli_fetch_array($tokenresult);
    extract($tokenrow);
}
$time_created = json_decode($token)->created;
$t = time();
$timediff = $t - $time_created;

$refreshToken = json_decode($token)->refresh_token;

// Initialize Google client
$client = new Google_Client();
$client->setApplicationName('');
$client->setScopes(array());
$client->setClientId('');
$client->setClientSecret('');
$client->setRedirectUri('');
$client->setAccessType('offline');
$client->setDeveloperKey('');

// Refresh token if expired
if (($timediff > 3600) && ($token != '')) {
    $refreshquery = "SELECT * FROM token WHERE type='refresh'";
    $refreshresult = mysqli_query($cxn, $refreshquery);

    // If refresh token exists
    if ($refreshresult != 0) {
        $refreshrow = mysqli_fetch_array($refreshresult);
        extract($refreshrow);
        $refresh_created = json_decode($token)->created;
        $refreshtimediff = $t - $refresh_created;

        // If refresh token is also expired
        if ($refreshtimediff > 3600) {
            $client->refreshToken($refreshToken);
            $newtoken = $client->getAccessToken();
            $tokenupdate = "UPDATE token SET token='$newtoken' WHERE type='refresh'";
            mysqli_query($cxn, $tokenupdate);
            $token = $newtoken;
            echo "refreshed again";
        } else {
            $client->setAccessToken($token);
            echo "use refreshed token but not time yet";
        }
    } else {
        $client->refreshToken($refreshToken);
        $newtoken = $client->getAccessToken();
        $tokenupdate = "INSERT INTO token (type, token) VALUES ('refresh', '$newtoken')";
        mysqli_query($cxn, $tokenupdate);
        $token = $newtoken;
        echo "refreshed for first time";
    }
}

// If token is still valid
if (($timediff < 3600) && ($token != '')) {
    $client->setAccessToken($token);
}

$service = new Google_DfareportingService($client);
Copier après la connexion

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!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal