LoginSignup
0
0

More than 5 years have passed since last update.

APi Gateway Platform Apigee (2) Basic Authentication/APi Key Authentication

Posted at

下記の記事ではApigeeの説明と、基礎的な操作について記載しました。

APi Gateway Platform Apigee (1) XMLからJSONへのデータ変換
http://qiita.com/snomoto/items/3a68d5127e703505b23f

本記事においては、APi Gatewayとして期待されるセキュリティまわりの機能を利用してみたいと思います。

タイトルにBasic Authenticationとありますが、ApigeeはBasic認証自体を提供はしていません

https://community.apigee.com/questions/2277/please-share-adding-basic-authentication-policy-ex.html
Answer by arghya das · Mar 30, 2015 at 03:39 PM @nagesh If you are trying to use the Basic Authentication policy for protecting your api, then that's not the right usage for the policy. The policy is not meant to provide basic authentication for a resource or apiproxy, rather it allows you to encode/decode a basic authentication header.

色々といじって時間を使ってしまいました。皆様方におかれましては時間を無駄になさらぬよう、ここに明記しておきます!

2016年11月に、Apigeeの管理画面のデザインが大幅に変更されました。
新デザインにてAPiを作成し、API Keyを用いた認証機能を利用してみたいと思います。

APi Gatewayの作成

  • 左のリストの一番上の「Develop」をクリックします。 apigeeNew01.png
      
  • 左のリスト2列目、2番目の「APi Proxies」をクリックします。下図の①
  • 次に、右上の「+Proxy」をクリックします。下図の②
    ApigeeNew02.png

      

  • 旧デザインと同じ画面になりますので、同じようにAPiを作成します。「Reverse proxy(most common)」でOKです。
    ApigeeNew03.png
      

  • 設定入力画面、"Proxy Name"のところ、名前としては分りやすいように"apikey"とでもしましょう。"Existing APi"にはAPi Gatewayの向こう側に置きたいAPiエンドポイント(ターゲット)URLを指定します。

      

  • そして、次にSecurityの設定入力が出ますが、ここで「API Key」を選択します。また「Publish API Product」にもチェックを入れてください。
    key001.png
       
         

  • prodとtestの両方の環境をdeployし、APi Gatewayの作成は完了です。

    apigeen006R.png

作成したエンドポイントURLをクリックして、下記のようなメッセージが出ればアクセス制御できています。
{"fault":{"faultstring":"Failed to resolve API Key variable request.queryparam.apikey","detail":{"errorcode":"steps.oauth.v2.FailedToResolveAPIKey"}}}

APi Keyを払い出す

  • Summary画面としては旧デザインと大きく異なってはいないようですね。(タブが横幅にフィットしない仕様含めて…)

  • 左側のアイコンリストから、「PUBLISH」→「Developers」を選択します。
    api002.png

  • 謎のテスト用アカウントが表示されていると思うのですが、一方で自分自身がリストに入っていません。
    画面右上の 「+Developer」ボタンから自分の情報を入力して「Save」します。
      

  • 次に、左側のリストから、「PUBLISH」→「Apps」を選択します。
    api003.png
      

  • 画面右上の「+Apps」ボタンから、アプリケーションを登録します。

    • 下図①のNameには分かりやすいように「apikeydevapp」と入力します。
    • Display Nameは上記の「apikeydevapp」が自動で反映されるはずです。
    • 下図②のDeveloperには、先ほど登録した自分自身を選択します。
    • 下図③のProductsには、作成した「apikey」を選択します。
      • 「Save」してください。

api004.png
  

  • 作成したApps、「apikeydevapp」をクリックしてみると、Credentials情報が記載されたページに遷移するかと思います。Consumer Keyの欄の「Show」ボタンを押すと、文字列が表示されます。これがAPi Keyとなります。
    api005.png

  • 改めてAPi Keyをパラメータに入れて、アクセス制御しているエンドポイントにアクセスしてみましょう。下記のように、apikeyというパラメータとして渡せばOKです。
    http://{xxxxxxxxxxxxxxxx}-prod.apigee.net/apikey?apikey=Consumer Keyのコピペ

アクセスできましたでしょうか?
これで、エンドポイントのアクセス制御を実現することができました。

0
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
0
0