このページでは、API キー メソッドを使用して次の操作を行う方法について説明します。
始める前に
このページでは、oauth2l コマンドライン ツールで curl
を使用して、API キーの API にリクエストを送信します。API を試すための詳細については、API キーを使ってみるをご覧ください。
プロジェクト内の API キーの一覧表示
ListKeys
メソッドを使用すると、Google Cloud プロジェクトが所有するすべてのキーのリストを取得できます。
gcurl https://apikeys.googleapis.com/v2/projects/PROJECT_NUMBER/locations/global/keys
成功すると、次のようなレスポンスが返されます。
{ "keys": [ { "name": "projects/12345678/locations/global/keys/2885bf87-5b84-47fa-92af-08c3e9337349", "displayName": "API key 2", "createTime": "2019-05-29T22:07:22.036Z", "uid": "2885bf87-5b84-47fa-92af-08c3e9337349", "updateTime": "2019-05-29T22:07:22.058623Z", "restrictions": { "androidKeyRestrictions": {} }, "etag": "zHib8eXEMCxe4ayQEbIaZg==" }, { "name": "projects/12345678/locations/global/keys/a4db08b7-5729-4ba9-8c08-f2df493465a1", "displayName": "API key 1", "createTime": "2019-05-29T22:06:58.844Z", "uid": "a4db08b7-5729-4ba9-8c08-f2df493465a1", "updateTime": "2019-05-29T22:06:58.855103Z", "restrictions": { "androidKeyRestrictions": {} }, "etag": "0L5KcPMGoNi53K5+FqPxiw==" } ] }
デフォルトでは、ListKeys
メソッドは使用可能な API キーのリストを返します。
削除とマークされたリストキーを表示するには、filter=state:DELETED
を使用してクエリ パラメータを追加します。
gcurl https://apikeys.googleapis.com/v2/projects/PROJECT_NUMBER/locations/global/keys?filter=state:DELETED
成功すると、次のようなレスポンスが返されます。
{ "keys": [ { "name": "projects/12345678/locations/global/keys/5d3564ad-f08e-48df-b0ca-0f50858ba3f2", "displayName": "Key 1", "createTime": "2019-06-12T04:47:30.214Z", "uid": "5d3564ad-f08e-48df-b0ca-0f50858ba3f2", "updateTime": "2021-03-05T22:35:37.387645Z", "deleteTime": "2021-03-05T22:35:37.290544Z", "etag": "V96UGAyyz+6sUHttzK42pQ==" }, { "name": "projects/12345678/locations/global/keys/7ad567fa-c11b-4903-99dc-88f89da7d73a", "displayName": "Key 2", "createTime": "2019-06-12T00:47:27.778Z", "uid": "7ad567fa-c11b-4903-99dc-88f89da7d73a", "updateTime": "2021-03-05T22:23:57.002187Z", "deleteTime": "2021-03-05T22:23:56.350234Z", "etag": "njPE6YjwHlrh6TLyxHibBg==" } ] }
deleteTime
フィールドは、削除コマンドが発行されたときに格納されます。キーは、削除コマンドの発行から 30 日後に完全に削除されます。
プロジェクト内に多数の API キーがある場合は、結果の出力を分割して任意の結果数を表示することも可能です。ページあたりの結果数または結果を制御するには、返される結果の数に pageSize
クエリ パラメータを追加します。
gcurl https://apikeys.googleapis.com/v2/projects/PROJECT_NUMBER/locations/global/keys?pageSize=25
レスポンスの末尾に nextPageToken
フィールドが含まれます。次のページを取得するには、pageToken
クエリ パラメータを追加して、次の呼び出しでトークンを含めます。
gcurl 'https://apikeys.googleapis.com/v2/projects/PROJECT_NUMBER/locations/global/keys?pageSize=25&pageToken=TOKEN'
&
は特殊な Bash 文字であるため、URL を一重引用符で囲む必要があります。
API キーのメタデータの取得
特定の API キーに関するメタデータを取得するには、Key.name
を使用して GetKey
メソッドを呼び出します。
gcurl https://apikeys.googleapis.com/v2/projects/PROJECT_NUMBER/locations/global/keys/KEY_ID
キー文字列の取得
セキュリティ上、ListKeys
メソッドと GetKey
メソッドは Key.keyString
を返しません。API キーの keyString
を取得するには、Key.name
を使用して GetKeyString
メソッドを呼び出します。
gcurl https://apikeys.googleapis.com/v2/Key.name/keyString
呼び出し元のユーザーに GetKeyString
メソッドを呼び出すには、apikeys.keys.getKeyString
権限が必要です。
キー文字列でキー名とプロジェクトを検索
keyString
があり、API キーを所有するプロジェクトを name
で検索する必要がある場合は、LookupKey
メソッドを呼び出して keyString
クエリ パラメータを指定します。を参照してください。
gcurl https://apikeys.googleapis.com/v2/keys:lookupKey?keyString=KEY_STRING
レスポンスは次のようになります。
{ "parent": "projects/12345678/locations/global", "name": "projects/12345678/locations/global/keys/2c437be3-1c77-417b-8f6f-748189760227" }
レスポンスには以下が含まれています。
parent
フィールドには、API キーが作成された Cloud プロジェクトのプロジェクト番号が含まれます。name
フィールドには、API キーの一意の識別子が含まれます。