PHP による暗号化と CryptoJS による復号化
データの暗号化と復号化により、安全な通信とデータ ストレージが確保されます。このガイドでは、PHP でデータを暗号化し、CryptoJS を使用してデータを復号化し、追加のセキュリティ層を提供するプロセスについて説明します。
PHP 暗号化と Base64 エンコーディング
-
PHP でデータを暗号化します: 次のパラメーターを指定して mcrypt_encrypt 関数を使用します:
- 暗号化アルゴリズム (MCRYPT_RIJNDAEL_256 など)
- 暗号化キー
- 暗号化される平文
- 暗号化モード (MCRYPT_MODE_CBC など)
- 暗号の初期化ベクトル (IV)
-
暗号化データを Base64 としてエンコード:base64_encode を使用して、暗号化データを Base64 文字列に変換します。この手順は、暗号化されたデータを安全に送信するために重要です。
CryptoJS を使用した JavaScript 復号
-
Base64 でエンコードされたデータの解析: CryptoJS.enc.Base64.parse を使用して、Base64 でエンコードされたデータを元の暗号化された形式にデコードします。
-
暗号化データの復号化: CryptoJS AES インスタンスを作成し、復号化メソッドを使用して暗号化キーを使用してデータを復号化します。
-
復号化されたデータの出力: toString(CryptoJS.enc.Utf8) を使用して復号化されたデータを文字列に変換します。
問題と解決策
- 暗号化プロセスと復号化プロセスの両方でまったく同じ暗号化キーが使用されていることを確認します。
- 次を使用して CryptoJS ライブラリが JavaScript コードにロードされていることを確認します。正しいバージョン。
- 暗号化中に使用された IV が復号化中にアクセス可能であることを確認します。
CryptoJS 互換性用の代替 PHP ライブラリ
CryptoJS 3.x および OpenSSL サポートによる PHP との互換性が向上しているため、GitHub の「cryptojs-aes-php」ライブラリの使用を検討してください。このライブラリは、データの暗号化と復号化のためのシンプルなインターフェイスを提供し、手動による Base64 エンコードと IV の処理の必要性を排除します。
以上がPHP でデータを暗号化し、CryptoJS で復号化する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。