Google-api-php Refresh Token返回invalid_grant

时间:2013-01-14 00:01:19

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

我几乎搜索了谷歌第一页的每一个结果。但似乎无法找到答案。我正在使用Google API的refresh_token并接收:

Error refreshing the OAuth2 token, message: '{ "error" : "invalid_grant" }

我正在做什么。首先:我正在创建并存储与google api的持久连接:

$client = new Google_Client();
$client->setClientId('xxxxxx-s73q0pa41aq3i2kcpatmpas6e6kkp99h.apps.googleusercontent.com');
$client->setClientSecret('xxxxxxxxxxxx');
$client->setRedirectUri('http://xxxxxxxx/generaterefreshtoken.php');
$client->setScopes(array('https://www.googleapis.com/auth/drive'));
$client->setAccessType('offline');


if (isset($_GET['code'])) {
  $client->authenticate();
  $_SESSION['token'] = $client->getAccessToken();
  $redirect = 'http://' . $_SERVER['HTTP_HOST'] . $_SERVER['PHP_SELF'];
  header('Location: ' . filter_var($redirect, FILTER_SANITIZE_URL));
}

if (isset($_SESSION['token'])) {
 $client->setAccessToken($_SESSION['token']);
}

if (isset($_REQUEST['logout'])) {
  unset($_SESSION['token']);
  $client->revokeToken();
}

if ($client->getAccessToken()) {

    $jsonarray = json_decode($client->getAccessToken());
    $arrGoogleAuth['access_token']=$jsonarray->access_token;
    $arrGoogleAuth['refresh_token']=$jsonarray->refresh_token;
    //filewrite

    $myFile = "refreshtoken.conf";
    $fh = fopen($myFile, 'w') or die("can't open file");
    fwrite($fh, $client->getAccessToken());
    fclose($fh);


    /*

    die();

    $service = new Google_DriveService($client);
    $file = new Google_DriveFile();
    $file->setTitle('My document.txt');
    $file->setDescription('A test document');
    $file->setMimeType('text/plain');

    $data = file_get_contents('document.txt');

    $createdFile = $service->files->insert($file, array(
          'data' => $data,
          'mimeType' => 'text/plain',
        ));

    print_r($createdFile);
*/



  // The access token may have been updated lazily.
  $_SESSION['token'] = $client->getAccessToken();
} else {
  $auth = $client->createAuthUrl();
  header("Location: $auth");
}

所以基本上一切都运行,令牌存储在文本文件中:

{
"access_token":"xxxxxxxxxxxxxxxN4U0ys2wy5monxs0Xh5fu5ayKL0OIENo-d1sN6g3YA",
"token_type":"Bearer",
"expires_in":3600,
"refresh_token":"xxxxxxxxxxxxDON-l90BNUcJgnkfZWDfg",
"created":1358120143
}

当我尝试使用以下代码进行身份验证时:

$client = new Google_Client();
$client->setClientId($googleDriveConfig['clientid']);
$client->setClientSecret($googleDriveConfig['clientsecret']);
$client->setRedirectUri(curPageURL);
$client->setScopes(array('https://www.googleapis.com/auth/drive'));
$client->refreshToken(file_get_contents('../_config/refreshtoken.conf'));
$client->authenticate();

我收到以下错误:     刷新OAuth2令牌时出错,消息:'{“error”:“invalid_grant”}

5 个答案:

答案 0 :(得分:6)

如果您在令牌未过期时尝试刷新,则会收到“invalid_grant”错误。

而不是:

$client->refreshToken(file_get_contents('../_config/refreshtoken.conf'));

使用此:

$client->setAccessToken(file_get_contents('../_config/refreshtoken.conf'));

您的令牌过期后,您的刷新应该有效。

答案 1 :(得分:3)

invalid_grant表示授权代码已被使用($GET['code']中可用)或Google API控制台中配置的应用程序类型无效。

确保在Google API控制台中注册应用时选择“Web应用程序”。

答案 2 :(得分:0)

对我有用的功能如下

$客户端 - > setAccessType(" refresh_token&#34);

答案 3 :(得分:0)

我碰到了类似的东西,对我来说问题是我的系统时钟(在我运行代码的Docker VM中)与实时不同步。因此,您要求过去或将来创建日期过长的令牌,而OAuth拒绝这样做。

报告here提示我。

答案 4 :(得分:-4)

在进行身份验证之前,必须有以下内容:

$client->grantType("refresh_token")