Срок действия токена доступа к API Google Sheet истек

#php #google-oauth #google-sheets-api #google-api-php-client

#php #google-oauth #google-sheets-api #google-api-php-client

Вопрос:

Я новичок в Google API и пытаюсь следовать руководству по быстрому началу работы. Я настроил свой PHP-файл так же, как показано ниже

 function getClient()
{
    $client = new Google_Client();
    $client->setApplicationName('Google Sheets API PHP Quickstart');
    $client->setScopes(Google_Service_Sheets::SPREADSHEETS);
    $client->setAuthConfig('ddc.json');
    $client->setAccessType('offline');
    $client->setPrompt('select_account consent');
    $client->setApprovalPrompt('force');

    $tokenPath = 'token.json';
    if (file_exists($tokenPath)) {
        $accessToken = json_decode(file_get_contents($tokenPath), true);
        $client->setAccessToken($accessToken);
    }
    

    if ($client->isAccessTokenExpired()) {
        // Refresh the token if possible, else fetch a new one.
        if ($client->getRefreshToken()) {
            $client->fetchAccessTokenWithRefreshToken($client->getRefreshToken());
        } else {
            // Request authorization from the user.
            $authUrl = $client->createAuthUrl();
            printf("Open the following link in your browser:n%sn", $authUrl);
            print 'Enter verification code: ';
            $authCode = trim(fgets(STDIN));

            $accessToken = $client->fetchAccessTokenWithAuthCode($authCode);
            $client->setAccessToken($accessToken);

            if (array_key_exists('error', $accessToken)) {
                throw new Exception(join(', ', $accessToken));
            }
        }
        if (!file_exists(dirname($tokenPath))) {
            mkdir(dirname($tokenPath), 0700, true);
        }
        file_put_contents($tokenPath, json_encode($client->getAccessToken()));
    }
    return $client;
}
 

И использование для обновления листа, как показано ниже

 $client = getClient();
$service = new Google_Service_Sheets($client);
 

Во время включения API я выбрал https://example.com/sheet/oauth2callback URL-адрес обратного вызова, но в этом каталоге нет никаких файлов, связанных с oauth2callback, может быть, это проблема?

Я генерирую токен на своем ПК с Windows 10, используя CMD и генерируя токен. Затем я использую этот токен на своем хостинге, который запускает мой файл в браузере. Он работает нормально, но примерно через час токен истекает и снова просит меня сгенерировать токен с сообщением типа

 Open the following link in your browser:.....
 

Я читал, что его токен обновляется автоматически, и нам ничего не нужно делать, но в моем случае он не получает новый токен автоматически или, может быть, я что-то упускаю. Дайте мне знать, если кто-нибудь здесь может мне помочь.

Ответ №1:

Токены доступа — это токены с коротким сроком действия, срок их действия истекает через час, после чего пользователю необходимо либо повторно пройти проверку подлинности, либо вам следует запросить автономный доступ и сохранить токен обновления в своем коде, чтобы вы могли использовать его в будущем для запроса нового токена доступа, когда ваш текущий токен доступа долженистекает.

Предполагая, что у вас есть токен обновления, и он был установлен на вашем клиенте, следующий код будет обновляться по мере необходимости.

 // Refresh the token if it's expired.
if ($client->isAccessTokenExpired()) {
    $client->fetchAccessTokenWithRefreshToken($client->getRefreshToken());
}
 

Код, вырванный из Oauth2Authentication.php