[英]PHP Prepared statement login
我正在将密码哈希和SQL注入防御添加到我的Login系统中。 目前,我遇到了一个错误。
<?php
session_start(); //start the session for user profile page
define('DB_HOST','localhost');
define('DB_NAME','test'); //name of database
define('DB_USER','root'); //mysql user
define('DB_PASSWORD',''); //mysql password
$con = new PDO('mysql:host=localhost;dbname=test','root','');
function SignIn($con){
$user = $_POST['user']; //user input field from html
$pass = $_POST['pass']; //pass input field from html
if(isset($_POST['user'])){ //checking the 'user' name which is from Sign-in.html, is it empty or have some text
$query = $con->prepare("SELECT * FROM UserName where userName = :user") or die(mysqli_connect_error());
$query->bindParam(':user',$user);
$query->execute();
$username = $query->fetchColumn(1);
$pw = $query->fetchColumn(2);//hashed password in database
//check username and password
if($user==$username && password_verify($pass, $pw)) {
// $user and $pass are from POST
// $username and $pw are from the rows
//$_SESSION['userName'] = $row['pass'];
echo "Successfully logged in.";
}
else {
echo "Invalid.";
}
}
else{
echo "INVALID LOGIN";
}
}
if(isset($_POST['submit'])){
SignIn($con);
}
?>
在上面的代码中,当我输入有效的用户名和密码时,系统将输出“ Invalid”。 if语句中的password_verify()可能是错误的(因为如果删除它,我将成功登录)。 我确定我已经正确完成了查询的准备,绑定和执行? 有人知道它为什么这样做吗?
谢谢!
您正在执行SELECT *,并使用fetchColumn,因此结果取决于返回的列顺序。 您应该选择所需的特定列,或者以关联数组的形式获取整行,然后按列名进行访问。
您还应该解决其他两个问题:
采用
// it will be an array('name' => 'John', 'password_hash' => 'abcd')
// or FALSE if user not found
$storedUser = $query->fetch(PDO::FETCH_ASSOC);
代替
$username = $query->fetchColumn(1);
$pw = $query->fetchColumn(2);
因为fetchColumn移动结果的光标。 因此,第一次调用提取第一行的第一列,第二次调用将从SECOND行提取数据!
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.