8

我几乎搜索了谷歌第一页的所有结果。但似乎找不到答案。我正在使用 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”}

4

5 回答 5

6

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

而不是这个:

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

用这个:

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

一旦你的令牌过期,你刷新应该可以工作。

于 2014-04-24T18:50:49.280 回答
3

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

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

于 2013-01-27T07:30:00.473 回答
0

对我有用的功能如下

$client->setAccessType("refresh_token");

于 2016-05-30T10:20:36.417 回答
0

我遇到了类似的问题,对我来说问题是我的系统时钟(在我运行代码的 Docker VM 内部)与实时不同步。因此,您请求的令牌的创建日期在过去或将来太远,而 OAuth 将拒绝该令牌。

我是从这里的报告中得知的。

于 2016-09-26T03:38:10.390 回答
-4

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

$client->grantType("refresh_token")
于 2013-05-21T16:19:34.703 回答