ホームページ >バックエンド開発 >PHPチュートリアル >双方向暗号化により、PHP でのパスワードの保管と取得をどのように保護できるのでしょうか?
はじめに
取得が必要なパスワードの安全な保管については、双方向暗号化は不可欠です。この記事では、PHP でパスワードを暗号化および復号化し、ユーザーのアクセシビリティを維持しながらプライバシーを確保する方法について説明します。
PHP でのパスワードの暗号化と復号化
PHP でパスワードを暗号化するにはでは、mcrypt ライブラリを使用できます。次の関数は暗号化プロセスを示しています:
function encryptPassword($password, $key) { $iv = mcrypt_create_iv(mcrypt_get_iv_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_CBC), MCRYPT_DEV_URANDOM); return mcrypt_encrypt(MCRYPT_RIJNDAEL_128, $key, $password, MCRYPT_MODE_CBC, $iv); }
パスワードを復号化するには、同様の関数を使用します:
function decryptPassword($encryptedPassword, $key) { $iv = substr($encryptedPassword, 0, mcrypt_get_iv_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_CBC)); return mcrypt_decrypt(MCRYPT_RIJNDAEL_128, $key, substr($encryptedPassword, mcrypt_get_iv_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_CBC)), MCRYPT_MODE_CBC, $iv); }
安全な暗号化アルゴリズムの選択
暗号化アルゴリズム、Blowfish および Rijndael-128 について(AES-128) は、パスワード暗号化にとって安全な選択肢であると考えられています。ブルート フォース攻撃に対する高レベルの保護を提供します。
秘密キーのストレージ
暗号化に使用される秘密キーを保護することが不可欠です。秘密キーを保存するためのさまざまなオプションには次のものがあります:
秘密キーのユーザー入力の要求
パスワードを復号化する必要があるたびにユーザーに秘密キーの入力を要求すると、追加のセキュリティが確保されます。 安全。これにより、キーが侵害された場合でも不正アクセスが防止されます。
潜在的なセキュリティ脆弱性
軽減リスク
暗号化用の PHP クラスの例:
class Encryption { private $key = ''; private $algorithm = ''; public function __construct($key, $algorithm = MCRYPT_RIJNDAEL_128) { $this->key = $key; $this->algorithm = $algorithm; } public function encrypt($data) { $iv = mcrypt_create_iv(mcrypt_get_iv_size($this->algorithm, MCRYPT_MODE_CBC), MCRYPT_DEV_URANDOM); return mcrypt_encrypt($this->algorithm, $this->key, $data, MCRYPT_MODE_CBC, $iv) . $iv; } public function decrypt($data) { $ivSize = mcrypt_get_iv_size($this->algorithm, MCRYPT_MODE_CBC); $iv = substr($data, 0, $ivSize); return mcrypt_decrypt($this->algorithm, $this->key, substr($data, $ivSize), MCRYPT_MODE_CBC, $iv); } }
以上が双方向暗号化により、PHP でのパスワードの保管と取得をどのように保護できるのでしょうか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。