Azure Key Vault のシークレットについて

Key Vault は、パスワードやデータベース接続文字列などの汎用シークレットのセキュリティで保護されたストレージを提供します。

開発者から見ると、Key Vault API はシークレット値を文字列として受け取って返します。 Key Vault の内部では、シークレットはオクテット (8 ビット バイト) のシーケンスとして格納および管理され、最大サイズはそれぞれ 25k バイトです。 Key Vault サービスでは、シークレットのセマンティクスは提供されていません。 データを受け取り、暗号化し、格納して、シークレット識別子 ("id") を返すだけです。 後で識別子を使用して、シークレットを取得できます。

機密性の高いデータについては、クライアントで追加のデータ保護レイヤーを検討する必要があります。 たとえば、Key Vault に保存する前に別の保護キーを使用してデータを暗号化します。

Key Vault では、シークレットの contentType フィールドもサポートされています。 クライアントは、シークレットのコンテンツ タイプを指定して、取得されるときのシークレット データの解釈を支援できます。 このフィールドの最大長は 255 文字です。 推奨される使用方法は、シークレット データを解釈するためのヒントです。 たとえば、実装がパスワードと証明書の両方をシークレットとして格納する場合は、このフィールドを使用して区別します。 定義済みの値はありません。

暗号化

Key Vault 内のシークレットはすべて、暗号化した状態で格納されます。 Key Vault では、暗号化キーの階層を使用して保存中のシークレットを暗号化します。その階層内のすべてのキーは、FIPS 140-2 に準拠しているモジュールによって保護されます。 この暗号化は透過的に行われ、ユーザーによる操作は必要ありません。 ユーザーによって追加されたシークレットは、Azure Key Vault サービスによって暗号化され、ユーザーが読み取るとき自動的に暗号化が解除されます。

キー階層の暗号化リーフ キーは、各キー コンテナーに固有です。 キー階層の暗号化ルート キーはセキュリティ ワールドに固有であり、その保護レベルはリージョンによって異なります。

  • 中国: ルート キーは、FIPS 140-2 レベル 1 で検証されたモジュールによって保護されます。
  • その他のリージョン: ルート キーは、FIPS 140-2 レベル 2 以上で検証されたモジュールによって保護されます。

シークレットの属性

シークレット データに加えて、次の属性を指定できます。

  • exp: IntDate、省略可能、既定値は無期限exp (expiration time: 有効期限) 属性は、特定の条件の場合を除き、それを過ぎたらシークレット データを取得してはならない日時を示します。 このフィールドは、特定のシークレットで使用できないキー コンテナー サービスをユーザーに通知するための情報提供のみを目的としています。 その値は、IntDate 値を含む数値でなければなりません。
  • nbf: IntDate、省略可能、既定値は現在nbf (not before: 有効期間開始日時) 属性は、特定の条件の場合を除き、それより前はシークレット データを取得してはならない日時を示します。 このフィールドは情報提供のみを目的としています。 その値は、IntDate 値を含む数値にする必要があります。
  • enabled: boolean、省略可能、既定値は true。 この属性は、シークレット データを取得できるかどうかを指定します。 enabled 属性は、nbf および exp と合わせて使います。nbfexp の間で操作が発生する場合、enabled が true に設定されている場合にのみ許可されます。 nbf から exp までのウィンドウの外部での操作は、特定の条件下を除き、自動的に禁止されます。

シークレット属性を含むすべての応答に含まれる読み取り専用属性が他にもあります。

  • created: IntDate、省略可能。 created 属性は、このバージョンのシークレットが作成された日時を示します。 この属性が追加される前に作成されたシークレットについては、この値は null です。 その値は、IntDate 値を含む数値でなければなりません。
  • updated: IntDate、省略可能。 updated 属性は、このバージョンのシークレットが更新された日時を示します。 この属性が追加される前に最後に更新されたシークレットについては、この値は null です。 その値は、IntDate 値を含む数値でなければなりません。

各キー コンテナー オブジェクトの種類の一般的な属性については、「Azure Key Vault のキー、シークレット、証明書の概要」をご覧ください。

日付と時刻で制御される操作

シークレットの取得操作は、nbf / exp ウィンドウの外側の、有効期間前および期限切れ後のシークレットでも動作します。 有効期間前のシークレットの取得操作は、テスト目的に使用できます。 期限切れのシークレットの取得は、復旧操作に使用できます。

シークレットのアクセス制御

Key Vault で管理されているシークレットのアクセス制御は、そのシークレットを格納している Key Vault のレベルで提供されます。 シークレットのアクセス制御ポリシーは、同じキー コンテナー内のキーに対するアクセス制御ポリシーとは別です。 ユーザーは、1 つまたは複数のコンテナーを作成してシークレットを保持することができ、シークレットのセグメント化と管理に適切なシナリオを維持する必要があります。

次のアクセス許可は、コンテナーのシークレット アクセス制御エントリでプリンシパルごとに使用でき、シークレット オブジェクトに対して許可される操作を厳密に反映します。

  • シークレット管理操作に対するアクセス許可

    • get: シークレットを読み取ります
    • list: キー コンテナーに格納されているシークレットまたはシークレットのバージョンを一覧表示します
    • set: シークレットの作成
    • delete: シークレットを削除します
    • recover: 削除されたシークレットを復旧します
    • backup: キー コンテナー内のシークレットをバックアップします
    • restore: バックアップしたシークレットをキー コンテナーに復元します
  • 特権操作に対するアクセス許可

    • purge:削除されたシークレットをパージ (完全に削除) します

シークレットの処理について詳しくは、Key Vault REST API リファレンス内のシークレットの操作の説明をご覧ください。 アクセス許可の設定については、「Vaults - Create or Update」(コンテナー - 作成または更新) および「Vaults - Update Access Policy」(コンテナー -アクセス ポリシーの更新) をご覧ください。

Key Vault でアクセスを制御するための攻略ガイドについては、次の記事をご覧ください。

シークレットのタグ

タグの形式で、アプリケーション固有のメタデータをさらに指定できます。 Key Vault は最大 15 個のタグをサポートし、それぞれが 512 文字の名前と 512 文字の値を持つことができます。

Note

タグは、呼び出し元が list または get のアクセス許可を持っている場合に呼び出し元によって読み取ることができます。

使用シナリオ

使用する場合 使用例
パスワード、アクセス キー、サービス プリンシパル クライアント シークレットなどのサービス間通信の資格情報を安全に格納し、ライフサイクルを管理し、監視します。 - 仮想マシンで Azure Key Vault を使用する
- Azure Web アプリで Azure Key Vault を使用する

次のステップ