3v4l.org

run code in 300+ PHP versions simultaneously
<?php function rehashPassword($password, $hash) { if (password_needs_rehash($hash, PASSWORD_BCRYPT,['cost' => 12])) { // 計算コスト12で再ハッシュ化の必要があるかチェック echo 'パスワードを再ハッシュするよ!' . "\n"; $hash = password_hash($password, PASSWORD_BCRYPT, ['cost' => 12]); // 計算コスト12で再度ハッシュ化する // DBに保存しなおしとかそういう処理 } else { echo 'パスワードの再ハッシュは不要だよ!' . "\n"; } return $hash; } $password = 'GoemonLets5'; // パスワード $hash = password_hash($password, PASSWORD_BCRYPT, ['cost' => 11]); // 計算コスト11でハッシュ化する $hash = rehashPassword($password, $hash); // コスト11で暗号化されたハッシュに対してコスト12で暗合されているかチェックをかける $hash = rehashPassword($password, $hash); // 直前の処理でハッシュはコスト12に再計算されているので、再ハッシュは不要になる

preferences:
33.29 ms | 402 KiB | 5 Q