【问题标题】:Google Calendar API Token not refreshing谷歌日历 API 令牌不刷新
【发布时间】:2021-05-06 22:19:11
【问题描述】:

由于某种原因,当我的令牌过期时,我需要删除文件并重新连接,否则将无法正常工作。是因为没有存储新的token还是?

我有以下代码:

if(!$_GET['id']){
            echo print_r('BUSINESS NOT FOUND');
            exit();
        }else {

            $client = new Google_Client();
            $client->setApplicationName('Google Calendar API PHP Quickstart');
            $client->setScopes(Google_Service_Calendar::CALENDAR);
            $client->setAuthConfig(__DIR__ . '/client.json');
            $client->setAccessType('offline');
            $client->setPrompt('select_account consent');


            // Load previously authorized token from a file, if it exists.
            // The file token.json stores the user's access and refresh tokens, and is
            // created automatically when the authorization flow completes for the first
            // time.
            $tokenPath = '../Remindly/accounts/' . $_GET['id'] . '.json';
            if (file_exists($tokenPath)) {
                $accessToken = json_decode(file_get_contents($tokenPath), true);
                $client->setAccessToken($accessToken);
                return $client;
            }

            // If there is no previous token or it's expired.
            if ($client->isAccessTokenExpired()) {
                // Refresh the token if possible, else fetch a new one.
                if ($client->getRefreshToken()) {
                    $client->fetchAccessTokenWithRefreshToken($client->getRefreshToken());
                }
                // Save the token to a file.
                file_put_contents($tokenPath, json_encode($client->getAccessToken()));
            }

        }

【问题讨论】:

  • Define nothing works 你有错误信息吗?
  • @DalmTo - 我无法从日历中提取任何数据。我需要在存储令牌时删除文件并重新连接,以便整个工作正常。

标签: php google-api google-oauth google-calendar-api google-api-php-client


【解决方案1】:

如果令牌过期,您似乎没有返回client

修改您的代码,如 quickstart for PHP 所示,在函数结束时返回客户端 - 无论是访问令牌过期还是未过期:

...
if(...){
...
}else{
    $client = new Google_Client();
    $client->setApplicationName('Google Calendar API PHP Quickstart');
    $client->setScopes(Google_Service_Calendar::CALENDAR_READONLY);
    $client->setAuthConfig('credentials.json');
    $client->setAccessType('offline');
    $client->setPrompt('select_account consent');

    // Load previously authorized token from a file, if it exists.
    // The file token.json stores the user's access and refresh tokens, and is
    // created automatically when the authorization flow completes for the first
    // time.
    $tokenPath = 'token.json';
    if (file_exists($tokenPath)) {
        $accessToken = json_decode(file_get_contents($tokenPath), true);
        $client->setAccessToken($accessToken);
    }

    // If there is no previous token or it's expired.
    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%s\n", $authUrl);
            print 'Enter verification code: ';
            $authCode = trim(fgets(STDIN));

            // Exchange authorization code for an access token.
            $accessToken = $client->fetchAccessTokenWithAuthCode($authCode);
            $client->setAccessToken($accessToken);

            // Check to see if there was an error.
            if (array_key_exists('error', $accessToken)) {
                throw new Exception(join(', ', $accessToken));
            }
        }
        // Save the token to a file.
        if (!file_exists(dirname($tokenPath))) {
            mkdir(dirname($tokenPath), 0700, true);
        }
        file_put_contents($tokenPath, json_encode($client->getAccessToken()));
    }
    return $client;
}
...

【讨论】:

    猜你喜欢
    • 2013-09-13
    • 1970-01-01
    • 2017-04-19
    • 1970-01-01
    • 2017-09-29
    • 1970-01-01
    • 2019-10-28
    • 1970-01-01
    • 2019-01-11
    相关资源
    最近更新 更多