我几乎搜索了谷歌第一页的每一个结果。但似乎无法找到答案。我正在使用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”}
答案 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")