6

Google API の痛みは続きます...

スクリプトを使用して更新トークンを使用することができます。自動的に更新され、カレンダーへのアクセスが維持されます。カレンダーを操作でき、すべて問題ありません。

私は今、PHP用のGoogle APIクライアントの使用に移りたいと思っています。トークンが有効である間、昨日これが機能していましたが、現在は有効期限が切れています。リフレッシュトークンを使用して新しいトークンを取得し、保持する方法がわかりません将来期限切れになると認証します。

私はいくつかの参考文献を見つけて、これらを試しました - これまでのところ、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>";
}

私の以前の投稿と同様に、ここで何が起こっているのかわかりません。トークンの有効期限が切れています - 更新トークンを持っています。アクセスするたびに認証を自動的に更新するには、コードにどのような変更を加える必要がありますか。

編集:エラーコードは次のとおりです。The OAuth 2.0 access token has expired, and a refresh token is not available

さらに混乱を避けるために、解決しようとしていた上記の行をいくつかコメントアウトしました

ありがとうございました

4

1 に答える 1

10

OK - いくつかの投稿に基づいて、更新トークンを取得して新しいアクセス トークンを取得する問題を修正しました。アクセスを試みる前に、次のコードを使用しました。

if($client->isAccessTokenExpired()) {
    echo 'Access Token Expired'; // Debug
    $client->refreshToken('X/XXXXXX');
}

空白の部分refreshTokenが私の更新トークンです。キーをコードにハードコーディングしました。

キーをデータベースに保存することへの参照を見たので、これはおそらく正しい解決策ではありません。おそらく、現在のアクセストークンを更新トークンを使用してデータベースに保存し、必要に応じてこれらのフォームをデータベースから引き出すことができます。それらをコーディングしますか?

私が使用したこの方法が、有効期限が切れた後に再び機能することを願っています-指を交差させました!

于 2013-08-27T12:07:35.200 に答える