秘密鍵JWT認証の設定

秘密鍵JWT認証は、非対称鍵ペアで署名されたJWTアサーションを使用して、OIDC Connect Core Client Authentication 1.0によるクライアント認証をサポートします。新しいアプリケーションを作成してprivate_key_jwtを使用するか、既存のアプリケーションで認証に秘密鍵ペアを使用するように設定することができます。

前提条件

秘密鍵JWTを使用するようにアプリケーションを構成する前に、RSA鍵ペアを生成する必要があります。

秘密鍵JWTを構成する

Auth0 Dashboardを使用して、新しいアプリケーションを作成することができ、資格情報の構成や既存アプリケーションの更新にも使用できます。

秘密鍵JWTにアプリケーション資格情報方法を設定する前に、現在のclient_secretパラメーターを安全に保存することをお勧めします。client_secretパラメーターは、秘密鍵JWTの構成が完了すると非表示になります。

private_key_jwtに対する新しいアプリケーションの構成

  1. [Auth0 Dashboard] > [Applications(アプリケーション)] > [Application(アプリケーション)]に移動します。

  2. [Create Application(アプリケーションの作成)]を選択します。

  3. アプリケーションタイプを選択します。

  4. アプリケーション設定の下にある、[Credentials(資格情報)]タブを選択します。

  5. [Authentication Methods(認証方法)]の下にある、[Private Key JWT(秘密鍵JWT)]を選択します。

    秘密鍵JWT認証を構成する - Auth0 Dashboardの説明

  6. 資格情報の詳細を構成します。

    1. 資格情報の名前を入力します。

    2. PEMフォーマットまたはX.509証明書をアップロードします。

    3. アサーションに署名するアルゴリズムを選択します。

    4. 任意:カスタム有効期限を有効にします。[Set an explicit expiry date for this Credential(この資格情報への明確な有効期限の設定)]を選択し、未来の日付を設定します。

  7. [Add Credential(資格情報の追加)]を選択します。

既存のアプリケーションの構成

  1. [Auth0 Dashboard] > [Applications(アプリケーション)]に移動します。

  2. 更新したいアプリケーションを選択します。

  3. [Credentials(資格情報)]タブを選択します。

  4. [Private Key JWT(秘密鍵JWT)]を選択します。

  5. 資格情報の詳細を構成します。

    1. 資格情報の名前を入力します。

    2. PEMフォーマットまたはX.509証明書をアップロードします。

    3. アサーションに署名するアルゴリズムを選択します。

    4. 任意:カスタム有効期限を有効にします。[Set an explicit expiry date for this Credential(この資格情報への明確な有効期限の設定)]を選択し、未来の日付を設定します。

  6. [Add Credential(資格情報の追加)]を選択します。

クライアントシークレット認証の使用のためのアプリケーションの構成

  1. [Auth0 Dashboard] > [Applications(アプリケーション)] > [Applications(アプリケーション)]に移動し、更新したいアプリケーションを選択します。

  2. [Credentials(資格情報)]タブを選択します。

  3. クライアントシークレット(Post)またはクライアントシークレット(Basic)を選択します。

  4. [Save(保存)]を選択します。

資格情報の有効期限の更新

Auth0 Dashboardで、既存の資格情報の有効期限を更新できます。

  1. [Auth0 Dashboard] > [Applications(アプリケーション)] > [Applications(アプリケーション)]に移動し、更新したいアプリケーションを選択します。

  2. [Credentials(資格情報)]タブを選択します。

  3. 更新したい資格情報を選択し、[Edit Credential(資格情報の編集)]を選択します。

    Dashboard - Applications - Application Settings - Credentials - update expiry date

  4. [Set an explicit expiry date for this Credential(この資格情報への明確な有効期限の設定)]を選択し、未来の日付を設定します。

  5. [Update Credential(資格情報の更新)]を選択します。

資格情報の制限

Auth0では、秘密鍵JWT認証の設定において、RSA鍵ペアの最小サイズを2048ビット、最大サイズを4096ビットと定めています。アプリケーションでは、最大2つの資格情報を構成できます。

資格情報のローテーションを行う

鍵の漏洩を防ぐために、Auth0では定期的に鍵ペアをローテーションすることを推奨しています。その方法については、「資格情報のローテーションを行う」をお読みください。

もっと詳しく