3
0

AWSのAPI GatewayでAPIキーを作成〜設定

Last updated at Posted at 2024-03-31

はじめに

こんにちは、ユーゴです!
今回は、API GatewayでAPIキーを設定したく、方法をネットで調べていました。しかし、なかなか見つからず、少し苦労しました。最終的には、試行錯誤しているうちに、とても簡単な方法で実現できました。
この記事で、同じことで悩んでいる方が時間を浪費せず済むようになれば幸いです。

課題

AWSのAPI GatewayでAPIキーの作成〜設定がわからない。

解決

1. LambdaとAPI GatewayでAPIを作成, 設定

1-1. 作成

こちらについては、できる前提でお話しします。
なので、自作APIの実装手順がわからない方は、こちらの記事をご覧ください。

API超入門!最速で使えるAPIを実装する

1-2. APIキーを必須化

APIキーを必須化します。
リソースページから、「メソッドリクエスト」タブの「編集」ボタンをクリックしてください。

スクリーンショット 2024-03-31 13.58.41.png

「APIキーは必須です」をONにします。

スクリーンショット 2024-03-31 13.59.21.png

ONにしたら、「保存」をクリックします。

2. APIキーを作成する

API Gatewayの左メニューから、「APIキー」を選択します。
そして、「APIキーの作成」ボタンを押します。
スクリーンショット 2024-03-31 13.27.34.png

設定は以下のような感じで大丈夫です。

スクリーンショット 2024-03-31 13.30.04.png

大丈夫であれば、「保存」をクリックします。

3. 使用量プランを作成

個人的には、ここが肝心です。というのも、他の記事で言及されておらず、しかしAPIとAPIキーを連携させるために必要だからです。

3-1. 作成

APIの使用をどれだけ許可するかを設定します。
左メニューの「使用量プラン」をクリックして、「使用量プランを作成」ボタンをクリックしましょう。

スクリーンショット 2024-03-31 13.38.36.png

今回はテストなので、数値はかなり適当に入れました。リクエストのレート、バースト、クォータの設定は、プロジェクトに応じて適切に設定してください。

スクリーンショット 2024-03-31 13.41.05.png

クォータを9999にするなら、トグルをOFFにして無制限で良かった

大丈夫そうであれば、「使用量プランを作成」をクリックします。

3-2. ステージを関連付ける

作成された使用量プランのページから、「APIステージを追加」をクリックします。

スクリーンショット 2024-03-31 13.50.23.png

対象のAPIとステージを選択します。(APIとステージは「1. LambdaとAPI GatewayでAPIを作成する」で作成している想定です)

スクリーンショット 2024-03-31 13.54.14.png

選択したら、「使用量プランに追加」をクリックします。

4. APIキーを使用量プランに対応づける

2. APIキーを作成する」で作成したAPIキーのページを開きます。

スクリーンショット 2024-03-31 13.45.50.png

「使用量プランに追加」をクリックします。

スクリーンショット 2024-03-31 13.34.40.png

使用量プランを、「3. 使用量プランを作成」で作成したものにします。

スクリーンショット 2024-03-31 13.47.47.png

選択できたら、「保存」をクリックします。

試してみる

APIキーのページで、「APIキー」のカラムからAPIキーをコピーします。(左側のコピーボタンを押してください)

スクリーンショット 2024-03-31 13.55.55.png

あとは、curlなりpostmanなりで、リクエストを投げてください。
APIキーは、「x-api-key」という項目に入れるのがお決まりです。

リクエスト
curl "{エンドポイント}" --header "x-api-key:{APIキー}"
レスポンス
{"statusCode": 200, "body": "\"Hello from Lambda!\""}

POSTメソッドなら-X POSTをお忘れなく。

まとめ

いかがだったでしょうか。今回は、APIキーの設定方法についてを紹介しました。
とても簡単だし、個人でAPIを公開していく分にはかなり有用な方法だと思います。しかし、なぜかAPIキーの使い方について細かく言及してくれている記事が見つからなかったので、書いてみました。
お役に立てましたら、いいね, LGTM, フォローなどよろしくお願いします!

3
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
3
0