ホームページ >データベース >mysql チュートリアル >PHP 5.5 の「password_hash()」と「password_verify()」を安全なパスワード ストレージに正しく使用するにはどうすればよいですか?

PHP 5.5 の「password_hash()」と「password_verify()」を安全なパスワード ストレージに正しく使用するにはどうすればよいですか?

Barbara Streisand
Barbara Streisandオリジナル
2024-12-12 11:25:14450ブラウズ

How Can I Correctly Use PHP 5.5's `password_hash()` and `password_verify()` for Secure Password Storage?

PHP 5.5 のpassword_hash() およびpassword_verify() 機能を正しく使用する

パスワードを安全に保存することは重要ですが、PHP 5.5 のpassword_hash() を使用する提案された方法は、関数が正しくありません。

password_hash() は、ハッシュとソルトの両方を含むハッシュ文字列。ソルトとハッシュを別々に保存することはお勧めできません。代わりに、返されたハッシュをデータベースに直接保存します。

パスワードを検証するには、データベースからハッシュとソルトの両方を取得し、次のようにpassword_verify()を使用します。

$hashAndSalt = password_hash($password, PASSWORD_BCRYPT);
// Store $hashAndSalt in the database

// Verification
if (password_verify($password, $hashAndSalt)) {
    // Verified
}

さらに、 ext/mysql の非推奨の性質とデータベース ステートメントの潜在的なセキュリティ脆弱性を考慮してください。 mysqli または PDO を使用し、PHP ドキュメントのガイダンスに従って SQL インジェクション攻撃から保護することをお勧めします。

以上がPHP 5.5 の「password_hash()」と「password_verify()」を安全なパスワード ストレージに正しく使用するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。