我的最终目标是通过Google Gmail API向自己发送电子邮件。
这是我的问题。
当我获取访问令牌时,会弹出错误
Fatal error: Uncaught exception 'Google_Auth_Exception' with message 'Wrong number of segments in token: '
我在这里阅读Cloud endpoints oauth2 error "这并不意味着您的令牌无效" ,但我收到致命错误,导致我的脚本中断。
我的访问令牌如下所示 4 / MqiIIl5K4S3D4iiieHshQt5D4M79oo07SbhMn22oe2o.cswa8t9ZuDAfJvIeHux6iLYXpNQmlAI
如果我使用此令牌刷新页面,我将收到另一个错误,即
'Error fetching OAuth2 access token, message: 'invalid_grant: Invalid code.'
这是我的代码
<?php
include_once "templates/base.php";
echo pageHeader("Simple API Access");
require_once realpath(dirname(__FILE__) . '/../autoload.php');
$client = new Google_Client();
$client_id = '114600397795-j5sn0gvsdrup0s8dcmsj49iojp3m9biu.apps.googleusercontent.com';
$client_secret = 'm3Dzankql_rs1OGICsA3Hbtc';
$redirect_uri = 'http://alupa.com/gmail/examples/simple-query.php';
$client->setClientId($client_id);
$client->setClientSecret($client_secret);
$client->setRedirectUri($redirect_uri);
$client->addScope("https://www.googleapis.com/auth/gmail.readonly");
$client->addScope("https://mail.google.com/");
$apiKey = "AIzaSyCWXxrTshKsotxEYNZZCXxdVXhLeku55cw";
$client->setDeveloperKey($apiKey);
if (isset($_GET['code'])) {
$client->authenticate($_GET['code']);
$_SESSION['access_token'] = $client->getAccessToken();
//$redirect = 'http://' . $_SERVER['HTTP_HOST'] . $_SERVER['PHP_SELF'];
//header('Location: ' . filter_var($redirect, FILTER_SANITIZE_URL));
}else{
$client->setApplicationName("Client_Gmail_Examples");
}
if (isset($_SESSION['access_token']) && $_SESSION['access_token']) {
$client->setAccessToken($_SESSION['access_token']);
} else {
$authUrl = $client->createAuthUrl();
}
if ($client->getAccessToken()) {
$_SESSION['access_token'] = $client->getAccessToken();
$token_data = $client->verifyIdToken()->getAttributes();
}
?>
<div class="box">
<div class="request">
<?php
if (isset($authUrl)) {
echo "<a class='login' href='" . $authUrl . "'>Connect Me!</a>";
} else {
echo "<a class='logout' href='?logout'>Logout</a>";
}
?>
</div>
</div>
alupa.com是我的本地域名,我没有看到任何问题
中的原始库答案 0 :(得分:5)
变化:
$token_data = $client->verifyIdToken()->getAttributes();
为:
$tuan = $client->getAccessToken();
$token_data = $client->verifyIdToken($tuan->id_token);
答案 1 :(得分:2)
您需要添加范围openid,然后获得id_token以及访问令牌。然后使用带有$ client-&gt; verifyIdToken
的id令牌