検索
ホームページバックエンド開発PHPチュートリアルPHP での API 認証と暗号化に JWT と JWE を使用する方法

インターネットの発展に伴い、データ対話のための API インターフェイスを提供する必要がある Web サイトやアプリケーションがますます増えています。この場合、APIの認証と暗号化が非常に重要な問題となります。一般的な認証および暗号化メカニズムとして、JWT と JWE が PHP で使用されることが増えています。さて、この記事では、PHP で API 認証と暗号化に JWT と JWE を使用する方法を説明します。

  1. JWT の基本概念

JWT は JSON Web Token の略で、2 者間で情報を安全に送信するためのコンパクトな自己完結型メカニズムです。これは、ヘッダー、ペイロード、署名の 3 つの部分で構成されます。ヘッダーにはトークンのタイプとアルゴリズム情報が含まれ、ペイロードには送信する必要のあるデータが含まれ、署名はデータの信頼性を検証するために使用されます。

以下は JWT の例です:

eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ.SflKxwRJSMeKK F2QT 4fwpMeJf36POk6yJV_adQssw5c

ヘッダーは {"alg": "HS256", "typ": " ですJWT "}、ペイロードは {"sub": "1234567890"、"name": "John Doe"、"iat": 1516239022}、署名は SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c です。

  1. PHP で API 認証に JWT を使用する

PHP で認証に JWT を使用するには、PHP-JWT などの JWT ライブラリを使用する必要があります。具体的な手順は以下のとおりです。

(1) PHP-JWT ライブラリをダウンロードしてインストールします。 Composer 経由でインストールできます。

(2) 次のコードを使用してエンコードおよびデコードします:

// Encode JWT
$jwt = JWT::encode($payload, $key);

//Decode JWT
$decoded = JWT::decode($jwt, $key, array('HS256'));

このうち、$payload は送信する必要があるデータです、$key は署名です。キーは必要に応じて設定できます。

(3) API での認証

API での認証に JWT を使用する基本的な考え方は、ユーザーが正常にログインした後、サーバーが JWT を生成し、 JWT ユーザーに送信され、ユーザーは API にアクセスするときに JWT を持参する必要があります。サーバーはリクエストを受信したときに JWT をデコードして検証し、ユーザーの ID が正当であるかどうかを判断します。

  1. JWE の基本概念

JWE は JSON Web Encryption の略で、データを暗号化して保護するためのメカニズムです。また、ヘッダー、暗号化されたコンテンツ、暗号化キーの 3 つの部分で構成されます。ヘッダーには暗号化アルゴリズムと鍵管理方法に関する情報が含まれ、暗号化コンテンツには暗号化が必要なデータが含まれ、データを復号化するために暗号化鍵が使用されます。

以下は JWE の例です:

eyJhbGciOiJSU0EtT0FFUCisImVuYyI6IkEyNTZHQ00iLCJraWQiOiIxMjM0NSIsImlzcyI6InNvbWVDbGllbnQiLCJjcml0IjpbImI2NCJdLCJzdWIiOiIxMjM 0NTY3ODkw IiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ.gXA0McEJXO_ejzOqzUwy_sx14ISFH7ksjwSYZdarlMQRzgb-gMQapghrpyv6grXBTJZbOQxBBzNU8w0WLwZijlNQ6QVY_ wVQ W8cm-W-IM9-rwqw4z6c17LUwJdd_0d9PuX_AhJIu5FKkeqMqYfZXMrE4IlO-9XxWA6sv_aWUjc5QifAAOfQCFx9ICpJ-s1iCZKc8R44vhPdujfA7Pj8bhEsuYUxj04b1g_JqZYloB 04yu9wW8 Hu76IlLvAhL19VE4FYsOa9cuXQc4kzbd4x-vylbMnSFzVDqt5PNZPd0-CQq7UZmI_i9tlxK-BW9XWauqQaN6UOsNwcl66uV9TxWg.AxY8DCtDaGlsbGljb3RoZQ.SflKxwRJS MeKKF2 QT4fwpMeJf36POk6yJV_adQssw5c

このうち、ヘッダーは {"alg": "RSA-OAEP", "enc": "A256GCM", "kid": "12345", "iss": "someClient", "crt": ["b64"]} 、暗号化されたコンテンツは {"sub": "1234567890", "name": "John Doe", "iat": 1516239022}、暗号化キーは AxY8DCtDaGlsbGljb3RoZQ です。

  1. PHP で API 暗号化に JWE を使用する

PHP で暗号化に JWE を使用するには、php-jose などの JWE ライブラリが必要です。具体的な手順は次のとおりです。

(1) php-jose ライブラリをダウンロードしてインストールします。 Composer 経由でインストールできます。

(2) 次のコードを使用してエンコードおよびデコードします。

// Encode JWE
$jwe = (new JWE())

->setPayload($data)
->addRecipient(new JWK($key))
->setAlgorithm('RSA-OAEP')
->setEncryptionAlgorithm('A256GCM')
->addHeader('kid', '12345');

$compact_jwe = $ jwe->toCompactJSON();

// JWE
$jwe = JWE::loadFromCompact($compact_jwe);
$jwk = new JWK($key);
$ plaintext = $jwe->decrypt($jwk);

このうち、$data は暗号化が必要なデータ、$key は必要に応じて設定できる暗号化キーです。

(3) API での暗号化

API での暗号化に JWE を使用する基本的な考え方は、サーバーが API 応答を生成するときに、JWE を使用して応答データを暗号化し、その後、最終データはクライアントに送信され、クライアントは応答を受信した後にそれを復号化します。

  1. 概要

この記事では、PHP での API 認証と暗号化に JWT と JWE を使用する方法について説明します。 JWT を使用すると、API リクエストの ID の正当性とデータの整合性を確保でき、JWE を使用すると、API 応答データの機密性を確保できます。実際のプロジェクトでは、ニーズに応じて適切な認証および暗号化メカニズムを選択できます。

以上がPHP での API 認証と暗号化に JWT と JWE を使用する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
どのデータをPHPセッションに保存できますか?どのデータをPHPセッションに保存できますか?May 02, 2025 am 12:17 AM

phpssionscanStorestrings、numbers、arrays、andobjects.1.strings:textdatalikeusernames.2.numbers:integersorfloatsforcounters.3.arrays:listslikeshoppingcarts.4.objects:complextructuresthataresialized。

どのようにPHPセッションを開始しますか?どのようにPHPセッションを開始しますか?May 02, 2025 am 12:16 AM

tostartaphpsession、outsession_start()atthescript'sbeginning.1)placeitbe foreanyouttosetthesscookie.2)usesionsionsionsionserdatalikelogintatussorshoppingcarts.3)再生セッションインドストップレベントフィックスアタック

セッションの再生とは何ですか?また、セキュリティをどのように改善しますか?セッションの再生とは何ですか?また、セキュリティをどのように改善しますか?May 02, 2025 am 12:15 AM

セッション再生とは、新しいセッションIDを生成し、セッション固定攻撃の場合にユーザーが機密操作を実行するときに古いIDを無効にすることを指します。実装の手順には次のものが含まれます。1。感度操作を検出、2。新しいセッションIDを生成する、3。古いセッションIDを破壊し、4。ユーザー側のセッション情報を更新します。

PHPセッションを使用する際のパフォーマンスの考慮事項は何ですか?PHPセッションを使用する際のパフォーマンスの考慮事項は何ですか?May 02, 2025 am 12:11 AM

PHPセッションは、アプリケーションのパフォーマンスに大きな影響を与えます。最適化方法には以下が含まれます。1。データベースを使用してセッションデータを保存して応答速度を向上させます。 2。セッションデータの使用を削減し、必要な情報のみを保存します。 3.非ブロッキングセッションプロセッサを使用して、同時実行機能を改善します。 4.セッションの有効期限を調整して、ユーザーエクスペリエンスとサーバーの負担のバランスを取ります。 5.永続的なセッションを使用して、データの読み取り時間と書き込み時間を減らします。

PHPセッションはCookieとどのように異なりますか?PHPセッションはCookieとどのように異なりますか?May 02, 2025 am 12:03 AM

phpsesionsareserver-side、whilecookiesareclient-side.1)Sessionsionsionsoredataontheserver、aremoresecure.2)cookiesstoredataontheclient、cookiestoresecure、andlimitedinsizeisize.sesionsionsionivationivationivationivationivationivationivationivate

PHPはユーザーのセッションをどのように識別しますか?PHPはユーザーのセッションをどのように識別しますか?May 01, 2025 am 12:23 AM

phpidentifiesauser'ssessionsingsinssessionCookiesIds.1)whensession_start()iscalled、phpgeneratesauniquesidstoredsored incoookienadphpsessidontheuser'sbrowser.2)thisidallowsphptortorieSessiondatadata fromthata

PHPセッションを保護するためのベストプラクティスは何ですか?PHPセッションを保護するためのベストプラクティスは何ですか?May 01, 2025 am 12:22 AM

PHPセッションのセキュリティは、次の測定を通じて達成できます。1。session_regenerate_id()を使用して、ユーザーがログインまたは重要な操作である場合にセッションIDを再生します。 2. HTTPSプロトコルを介して送信セッションIDを暗号化します。 3。Session_Save_Path()を使用して、セッションデータを保存し、権限を正しく設定するためのSecure Directoryを指定します。

PHPセッションファイルはデフォルトで保存されていますか?PHPセッションファイルはデフォルトで保存されていますか?May 01, 2025 am 12:15 AM

phpsessionFilesToredInthededirectoryspecifiedBysession.save_path、通常/tmponunix-likesystemsorc:\ windows \ temponwindows.tocustomizethis:1)uesession_save_path()tosetaCustomdirectory、ensuringit'swritadistradistradistradistradistra

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

SecLists

SecLists

SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

Dreamweaver Mac版

Dreamweaver Mac版

ビジュアル Web 開発ツール