I’ve got:
mysql_connect($host,$username,$password);
@mysql_select_db("db") or die("Error: Cannot select database");
$query = "select password from users where name = '".$_POST['login-userid']."'";
$result = mysql_query($query);
if ($result == false) {
echo "Invalid username or password";
} else {
if (mysql_result($result,0) == hash('sha256', $_POST['login-password'])) {
echo "Logging in...";
}
}
For some reason I keep getting an error for the mysql_result line, even when it shouldn’t be executed (when the username doesn’t exist, ie $result evaluates to false).
mysql_query will only return
falseif there is an error. In this case there is no error, there are just 0 rows.You need to use mysql_num_rows to get the number of rows returned.