我对谷歌api的痛苦继续......
我可以使用脚本来使用刷新令牌 - 自动刷新并保持我对日历的访问权.我可以与日历互动,一切都很好.
我现在想继续使用谷歌api客户端的PHP,我昨天工作,虽然我的令牌有效,但现在已经过期我无法弄清楚如何使用刷新令牌获取新令牌并保持在将来过期后进行身份验证.
我找到了很多引用并尝试了这些 - 这是我的测试脚本到目前为止基于simple.php的例子:
<?php
require_once '../../src/Google_Client.php';
require_once '../../src/contrib/Google_CalendarService.php';
session_start();
$client = new Google_Client();
$client->setAccessType('offline');
$client->setApplicationName("Downs Golfmanager");
// Visit https://code.google.com/apis/console?api=calendar to generate your
// client id, client secret, and to register your redirect uri.
$client->setClientId('XXXXXX.apps.googleusercontent.com');
$client->setClientSecret('XXXXXX');
$client->setRedirectUri('XXXXXX');
$client->setDeveloperKey('XXXXXX');
$client->refreshToken('X/XXXXX');
$client->setUseObjects(true);
$cal = new Google_CalendarService($client);
if (isset($_GET['logout'])) {
unset($_SESSION['token']);
}
if (isset($_GET['code'])) {
$client->authenticate($_GET['code']);
$_SESSION['token'] = $client->getAccessToken();
header('Location: http://' . $_SERVER['HTTP_HOST'] . $_SERVER['PHP_SELF']);
}
if (isset($_SESSION['token'])) {
$client->setAccessToken($_SESSION['token']);
}
if($client->isAccessTokenExpired()) {
/
echo 'Access Token Expired'; // Debug
//$client->refreshToken($refreshToken);
}
if ($client->getAccessToken()) {
$event = new Google_Event();
$event->setSummary('Appointment');
$event->setLocation('Somewhere');
$start = new Google_EventDateTime();
$start->setDateTime('2013-08-28T14:00:00.000+01:00');
$event->setStart($start);
$end = new Google_EventDateTime();
$end->setDateTime('2013-08-28T15:25:00.000+01:00');
$event->setEnd($end);
$createdEvent = $cal->events->insert('XXXXXX@group.calendar.google.com', $event);
//echo "<pre>" . print_r($createdEvent, true) . "</pre>";
echo $createdEvent->getId();
//test pulling events
$events = $cal->events->listEvents('XXXXXX@group.calendar.google.com');
while(true) {
foreach ($events->getItems() as $event) {
echo $event->getSummary();
}
$pageToken = $events->getNextPageToken();
if ($pageToken) {
$optParams = array(
'pageToken' => $pageToken,
'timeMin'=>'2013-08-26T00:00:00+01:00',
'timeMax'=>'2013-08-31T00:00:00+01:00'
);
$events = $cal->events->listEvents('XXXXXX@group.calendar.google.com', $optParams);
} else {
break;
}
}
//print "<h1>Events List</h1><pre>" . print_r($events, true) . "</pre>";
$calList = $cal->calendarList->listCalendarList();
print "<h1>Calendar List</h1><pre>" . print_r($calList, true) . "</pre>";
$_SESSION['token'] = $client->getAccessToken();
} else {
$authUrl = $client->createAuthUrl();
print "<a class='login' href='$authUrl'>Connect Me!</a>";
}
Run Code Online (Sandbox Code Playgroud)
和我以前的帖子一样,我不清楚这里应该发生什么.我的令牌已过期 - 我有刷新令牌.每次访问时,我需要对代码进行哪些更改才能自动刷新授权.
编辑:错误代码是: The OAuth 2.0 access token has expired, and a refresh token is not available
我已经评论了几条额外的行,我将其纳入试图解决的尝试中,以避免进一步混淆
谢谢
Ray*_*Ray 10
好的 - 基于几个帖子,我已经修复了获取刷新令牌以获取新访问令牌的问题.在我开始尝试任何访问之前,我使用了这段代码:
if($client->isAccessTokenExpired()) {
echo 'Access Token Expired'; // Debug
$client->refreshToken('X/XXXXXX');
}
Run Code Online (Sandbox Code Playgroud)
消隐的部分refreshToken是我的刷新令牌.我将密钥硬编码到代码中.
这可能不是正确的解决方案,因为我已经看到了将密钥存储在数据库中的引用,因此我可能会将当前访问令牌存储在带有刷新令牌的数据库中,并将这些形式从db中拉出来并在需要时将其保存为硬盘编码吗?
希望我使用的这种方法在它过期后再次起作用 - 手指交叉!
| 归档时间: |
|
| 查看次数: |
9557 次 |
| 最近记录: |