ユーザーのパスワードを保存したいとします。これは、PHP 5.5 のpassword_hash()
関数 (または PHP 5.3.7+ のこのバージョン: https://github.com/ircmaxell/password_compat ) でそれを行う正しい方法でしょうか?
$options = array("cost" => 10, "salt" => uniqid());
$hash = password_hash($password, PASSWORD_BCRYPT, $options);
それから私はするだろう:
mysql_query("INSERT INTO users(username,password, salt) VALUES($username, $hash, " . $options['salt']);
データベースに挿入します。
次に確認します。
$row = mysql_fetch_assoc(mysql_query("SELECT salt FROM users WHERE id=$userid"));
$salt = $row["salt"];
$hash = password_hash($password, PASSWORD_BCRYPT, array("cost" => 10, "salt" => $salt));
if (password_verify($password, $hash) {
// Verified
}