0

私の最終目標は、 Google の APIから場所の詳細を取得できるようにすることです。

これはサーバーのバックグラウンド タスクとして開始されるため、これをService Accountとして行う必要があります。サービス アカウントでは、JWT (JSON Web トークン) をaccess_token と交換する必要があります。私はついにそれを機能させ、access_tokenを受け取りました。ふぅ。

しかし、この access_token をどうすればよいかわかりません。

Place Details API にはkeyパラメータが必要であると表示されていますが、キーがありません。ただの access_token です。その値を使用しkeyたり、パラメーターの名前を変更したりしても機能しaccess_tokenません。

最終的には、次のような URL にアクセスできるようにする必要があります。

https://maps.googleapis.com/maps/api/place/details/json?reference={MY_REFERENCE}&sensor=false&key={MY_ACCESS_TOKEN}

アクセス トークンを使用して Google Place Detail API にリクエストを送信するにはどうすればよいですか?

更新 1

まだ成功していませんが、Google に送信している内容に問題がある場合に備えて、リクエストの詳細を投稿すると思いました。

私はJWT Ruby ライブラリを使用しており、クレーム セットの値は次のとおりです。

{
  :iss => "54821520045-c8k5dhrjmiotbi9ni0salgf0f4iq5669@developer.gserviceaccount.com",
  :scope => "https://www.googleapis.com/auth/places",
  :aud => "https://accounts.google.com/o/oauth2/token",
  :exp => (Time.now + 3600),
  :iat => Time.now.to_i
}

私には正気に見えます。

4

2 に答える 2

0

サービスアカウントとその資格情報を作成します

サービスアカウントとその資格情報を作成する必要があります。この手順では、後でGoogle Appsのドメイン全体の権限の委任と、サービスアカウントで承認するためのコードで使用される3つのアイテムを収集する必要があります。これらの3つのアイテムはあなたのサービスアカウントです:

• クライアントID。

•秘密鍵ファイル。

• 電子メールアドレス。

これを行うには、最初に、GoogleCalendarAPIが有効になっている有効なGoogleAPIコンソールプロジェクトが必要です。次の手順を実行します:

  1. GoogleAPIコンソールに移動します。
  2. 既存のプロジェクトを開くか、新しいプロジェクトを作成します。
  3. サービスセクションに移動します。
  4. Calendar API(およびアクセスが必要な可能性のある他のAPI)を有効にします。

これで、サービスアカウントとその資格情報を作成できます。次の手順を実行します:

  1. APIアクセスセクションに移動します。

  2. [OAuth2.0クライアントIDの作成...]をクリックしてクライアントIDを作成します。

  3. 製品名を入力し、オプションのロゴを指定して、[次へ]をクリックします。

  4. アプリケーションタイプの入力を求められたらサービスアカウントを選択し、[クライアントIDの作成]をクリックします。

この時点で、秘密鍵をファイルとしてダウンロードできるダイアログが表示されます(下の画像を参照)。APIコンソールからファイルを再度ダウンロードする方法がないため、そのファイルをダウンロードして安全に保管してください。

ファイルをダウンロードしてダイアログを閉じると、サービスアカウントのメールアドレスとクライアントIDを取得できるようになります。

これで、サービスアカウントの秘密鍵ファイル、クライアントID、および電子メールアドレスが収集されたはずです。これで、ドメイン全体の権限をサービスアカウントに委任する準備が整いました。

ドメイン全体の権限をサービスアカウントに委任します

ここで作成したサービスアカウントには、アクセスするGoogleAppsドメインのユーザーデータへのアクセスを許可する必要があります。次のタスクは、GoogleAppsドメインの管理者が実行する必要があります。

  1. GoogleAppsドメインのコントロールパネルに移動します。URLは次のようになります:www.google.com/a/cpanel/mydomain.com

  2. [高度なツール...]に移動します...>サードパーティのOAuthクライアントアクセスを管理します。

  3. [クライアント名]フィールドに、サービスアカウントのクライアントIDを入力します。

  4. [1つ以上のAPIスコープ]フィールドに、アプリケーションにアクセスを許可する必要があるスコープのリストを入力します(下の画像を参照)。たとえば、Google Calendar APIへのドメイン全体のアクセスが必要な場合は、www.googleapis.com / auth/calendar.readonlyと入力します。

  5. [承認]ボタンをクリックします。

これで、サービスアカウントは、ドメインのすべてのユーザーがGoogleカレンダーAPIにドメイン全体でアクセスできるようになり、場合によっては上記の例にリストした他のAPIにアクセスできるようになります。

以下は、サービスアカウントを使用してPHPのカレンダーデータにアクセスする説明です。

ユーザーカレンダーへのサービスアカウントアクセスの一般的なプロセスは次のとおりです。

•Googleクライアントを作成します

•クライアントアプリケーション名を設定します

•すでにアクセストークンをお持ちの場合は、有効期限が切れているかどうかを確認してください

•アクセストークンの有効期限が切れている場合は、JWTアサーションクレデンシャルを設定して新しいトークンを取得します

•クライアントIDを設定します

•Googleクライアントに基づいて新しいカレンダーサービスオブジェクトを作成します

•カレンダーイベントを取得する

注:アクセストークンを保存し、有効期限が近づいたときにのみ更新する必要があります。そうしないと、ユーザーの一定期間内のアクセストークン数の制限を超えたというエラーが表示されます。

使用されたGooglePHPクライアントライブラリ関数の説明:

クライアントオブジェクトは多くのパラメータとメソッドにアクセスでき、次のすべてはクライアントオブジェクトを介してアクセスされます。

新しいクライアントオブジェクトを作成します。

$client = new Google_Client();

クライアントアプリケーション名を設定します。

$client->setApplicationName(“My Calendar App”);

クライアントアクセストークンをすでに保存している場合は、次のように設定します。

$client->setAccessToken($myAccessToken);

アクセストークンの有効期限が切れているかどうかを確認します。30秒のバッファがあるため、トークンが30秒以内に有効期限が切れるように設定されている場合、これはtrueを返します。アクセストークンの有効期間は1時間です。Accessトークンは、実際には、作成時刻、秒単位の有効期間、およびトークン自体を含むJSONオブジェクトです。したがって、トークンには有効期限が切れる時期を決定するためのすべての情報がローカルにあるため、Googleへの呼び出しは行われません。

$client->isAccessTokenExpired();

トークンの有効期限が切れているか、トークンを取得したことがない場合は、Accessトークンを取得するためにアサーションクレデンシャルを設定する必要があります。

$ client-> setAssertionCredentials(new Google_AssertionCredentials(SERVICE_ACCOUNT_NAME、array(CALENDAR_SCOPE)、$ key、'notasecret'、' http: //oauth.net/grant_type/jwt/1.0/bearer'、$ email_add));

Where:

SERVICE_ACCOUNT_NAMEは、以前に設定したサービスアカウントのメールアドレスです。

 For example:’abcd1234567890@developer.gserviceaccount.com’

CALENDAR_SCOPEは、Google管理インターフェースのスコープ設定です。

 For example: ‘https://www.googleapis.com/auth/calendar.readonly’

$ keyは、Googleアプリコンソールでプロジェクトを作成したときにダウンロードされたキーファイルのコンテンツです。$ email_addは、カレンダーデータを取得するユーザーのGoogleメールアドレスです。

クライアントIDを設定します:$ client-setClientId(SERVICE_CLIENT_ID); ここで、SERVICE_CLIENT_IDは、以前に設定されたサービスアカウントのクライアントIDです。例:'abcd123456780.apps.googleusercontent.com' </ p>

新しいカレンダーサービスオブジェクトを作成します。$cal= new Google_CalendarService($ client);

カレンダーの取得にはいくつかのオプションを設定できます。以下のコードでそれらのいくつかを設定します。これらはAPIドキュメントで定義されています。$ optEvents = array('timeMax' => $ TimeMax、'timeMin' => $ TimeMin、'orderBy' =>'startTime'、'singleEvents' =>'True');

カレンダーイベントのリストを取得し、上記のオプションを通話に渡します。

$calEvents = $cal->events->listEvents('primary', $optEvents);

返されたイベントリストをループします。リストはページングされるため、リストがなくなるまでページをフェッチする必要があります。

  foreach ($calEvents->getItems() as $event) {
// get event data
$Summary = $event->getSummary();
$description = $event->getDescription();
$pageToken = $calEvents->getNextPageToken();
            if ($pageToken) { // if we got a token the fetch the next page of events.
                    $optParams = array('pageToken' => $pageToken);
                    $calEvents = $cal->events->listEvents('primary', $optParams);
            } else {
                    break;
            }

}

アクセストークンを取得します。

$ myAccessToken = $ client-> getAccessToken();

次回のために、アクセストークンをパーマネントストアに保存します。

于 2013-03-05T15:27:04.050 に答える
0

言語は重要ではありません。php、ruby、.net、java プロセスは同じです。API のコンソールには、Places API がサポートされているサービス アカウントとして表示されるため、アクセスできるはずです。

トークンの使用に関しては、 https://code.google.com/p/google-api-ruby-client/ code をご覧ください。使用方法はコード リポジトリで明確に定義されています。アクセス トークンがサービス アカウント用であるか単一ユーザー用であるかに関係なく、トークンを使用するプロセスは同じです。次のリンクの「Google API の呼び出し」というタイトルのセクションを参照してください: https://developers.google.com/accounts/docs/OAuth2InstalledApp

アクセス トークンは、リクエストとともに http 認証ヘッダーで送信されます。カレンダー リクエストの場合は、次のようになります: GET /calendar/v3/calendars/primary HTTP/1.1 ホスト: www.googleapis.com コンテンツの長さ: 0 承認: OAuth ya29.AHES6ZTY56eJ0LLHz3U7wc-AgoKz0CXg6OSU7wQA

于 2013-03-11T16:25:53.673 に答える