JSON Web Encryption (JWE) は、RFC 7516 によって定義された標準で、JSON ベースのデータ構造を使用して暗号化されたコンテンツを表します。これにより、任意のペイロードを暗号化して機密性を確保し、必要に応じて整合性を確保できます。この暗号化されたコンテンツには、機密性の高いユーザー情報、セキュリティ トークン、さらにはファイルなど、あらゆる種類のデータが含まれる可能性があります。
JWE は、トークン、ユーザー情報、財務詳細などの機密データを安全に送信するために、Web アプリケーションや API で広く使用されています。これにより、情報が傍受された場合でも、権限のないエンティティによって情報が読み取られることがなくなります。暗号化されたペイロードは、正しい復号キーを所有する目的の受信者のみが復号して使用できます。
JSON Web Encryption (JWE) は、関係者間で情報を JSON オブジェクトとして安全に送信するための標準です。 JWE は暗号化を使用して、保護するデータの機密性と整合性を確保します。一般的な JWE 構造は、連結されピリオド (.) で区切られた 5 つの部分で構成されます。 5 つの部分は次のとおりです:
JWE の各部分は、暗号化と復号化のプロセスにおいて特定の役割を果たします。各部分を詳しく掘り下げてみましょう。
JOSE (JSON Object Signing and Encryption) ヘッダーは JWE の最初の部分であり、暗号化プロセスに関するメタデータが含まれています。これは、base64url でエンコードされた JSON オブジェクトであり、以下が含まれます:
例:
{ "alg": "RSA-OAEP", "enc": "A256GCM" }
このヘッダーは、コンテンツ暗号化キーが RSA-OAEP アルゴリズムを使用して暗号化され、ペイロードが 256 ビット キーの AES GCM を使用して暗号化されることを指定します。
JWE の 2 番目の部分は暗号化キーで、実際のデータ (ペイロード) を暗号化するために使用されるキーです。このキーは、JOSE ヘッダーの alg パラメータで指定されたアルゴリズムを使用して暗号化されます。
暗号化キーはbase64urlでエンコードされています。
初期化ベクトル (IV) は、JWE 構造の 3 番目のコンポーネントです。これは、base64url でエンコードされたランダムな値であり、同じ平文が毎回異なる方法で暗号化されることを保証するために暗号化アルゴリズムとともに使用されます。 IV は、暗号化データ内のパターンを防止し、セキュリティを強化します。
AES GCM モードの場合、IV は通常 96 ビット (12 バイト) の長さです。
暗号文は、コンテンツ暗号化キー (CEK) と暗号化アルゴリズム (enc パラメーター) を使用して平文 (ペイロード データ) を暗号化した結果です。暗号文はbase64urlでエンコードされており、保護されたコンテンツを保持するため、JWEの中核部分となります。
認証タグ ( タグ とも呼ばれる) は、暗号文、初期化ベクトル (IV)、および追加の認証データに整合性と信頼性を提供する、base64url でエンコードされた値です。 (AAD)。これは、AES GCM などのアルゴリズムを使用して暗号化プロセス中に生成されます。
暗号化後に JWE 構造の一部が変更された場合、認証タグが一致しないため、復号化プロセスは失敗します。
「Hello, World!」というメッセージを暗号化するシナリオを考えてみましょう。 JWEを使用します。簡略化した内訳は次のとおりです:
最終的な JWE は次のようになります:
{ "alg": "RSA-OAEP", "enc": "A256GCM" }
JWE は、公開キー暗号化 (対称キーの暗号化用) と対称暗号化 (実際のペイロードの暗号化用) を組み合わせて使用して機能します。プロセスの仕組みは次のとおりです:
鍵の生成と管理
暗号化プロセス
復号化プロセス
JWE の作成には、JWE 標準をサポートするライブラリの選択が含まれます。 Java で最も人気のあるライブラリの 1 つは、Nimbus JOSE JWT です。以下は、JWE の作成方法を示す簡単な例です:
依存関係のセットアップ
Maven を使用している場合は、次の依存関係を pom.xml に追加します。
{ "alg": "RSA-OAEP", "enc": "A256GCM" }
JWE の作成と暗号化
これは、JWE の作成を示す Java コード スニペットです。
eyJhbGciOiJSU0EtT0FFUCIsImVuYyI6IkEyNTZHQ00ifQ. g_hE3pPLiSs9C60_WFQ-VP_mQ1BU00Z7Xg. 48V1_ALb6US04U3b. 5eym8mytxoXCBlYkhjBtkmmI. XFBoMYUZodetZdvTiFvSkQ
コードの説明
結果
上記のコードを実行すると、暗号化された JWE 文字列が生成され、それが元のメッセージに復号化されます。
<dependency> <groupId>com.nimbusds</groupId> <artifactId>nimbus-jose-jwt</artifactId> <version>9.22</version> </dependency>
JSON Web Encryption (JWE) は、最新の Web アプリケーションで安全なデータ送信を行うために不可欠なツールです。その構造、仕組み、長所と短所を理解することは、アプリケーションでいつどのように使用するかを情報に基づいて決定するのに役立ちます。ご質問がある場合、またはさらに詳しい説明が必要な場合は、お気軽に以下にコメントを残してください。
で投稿の詳細をお読みください: JWE の理解: 構造、操作、利点、欠点、および JWE の作成方法
以上がJWE の理解: 構造、操作、利点、欠点、および JWE の作成方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。