「労働者が自分の仕事をうまくやりたいなら、まず自分の道具を研ぎ澄まさなければなりません。」 - 孔子、「論語。陸霊公」
表紙 > プログラミング > PHPのpassword_verify関数を使用してユーザーのパスワードを安全に検証するにはどうすればよいですか?

PHPのpassword_verify関数を使用してユーザーのパスワードを安全に検証するにはどうすればよいですか?

2024 年 11 月 5 日に公開
ブラウズ:152

How to Verify User Passwords Securely with PHP\'s password_verify Function?

PHP を使用した暗号化されたパスワードの復号化

多くのアプリケーションは、password_hash などの暗号化アルゴリズムを使用してユーザー パスワードを安全に保存します。ただし、ログイン試行を検証するときは、入力されたパスワードを暗号化されて保存されたバージョンと比較することが重要です。

暗号化の問題

password_hash は、Bcrypt を使用しています。ウェイ ハッシュ アルゴリズム。つまり、暗号化されたパスワードを元に戻したり復号したりすることはできません。これは、データベースが侵害された場合でも、攻撃者がプレーンテキストのパスワードにアクセスできないようにするセキュリティ機能です。

解決策: パスワードの検証

ユーザー パスワードを検証するには、password_verify 関数を使用します:

if (password_verify('input_password', $encrypted_password)) {
    // Password matches!
} else {
    // Invalid password.
}

この関数は、入力されたパスワードと暗号化されたバージョンを比較し、一致する場合に true を返します。

SQL クエリの変更

SQL クエリにパスワードを入力し、パラメータ化を使用します:

$sql_script = 'SELECT * FROM USERS WHERE username=?';

これは、悪意のあるユーザーがアクセスするのを防ぐことで、SQL インジェクション攻撃から保護します。クエリを操作します。

Example

password_verify の使用例を示します。

$username = $_POST['username'];
$input_password = $_POST['password'];

$sql_script = 'SELECT * FROM USERS WHERE username=?';

if ($result = $conn->query($sql_script, $username)) {
    if ($user = $result->fetch_assoc()) {
        if (password_verify($input_password, $user['password'])) {
            // Login successful!
        } else {
            // Invalid password.
        }
    } else {
        // User not found.
    }
}
最新のチュートリアル もっと>

免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。

Copyright© 2022 湘ICP备2022001581号-3