1 回答
TA贡献1806条经验 获得超8个赞
不,当变量通过引用传递时没有必要,这里就是这种情况。所以 Visual Studio 错了。
但是,您在这里使用的是过时的技术,并且可以消除这些误报警告并立即减少代码量:
$stmt = $conn->prepare("SELECT * FROM `users` WHERE user = ? ");
$stmt->bind_param("s", $filtered_form['user']);
$stmt->execute();
$row = $stmt->get_result()->fetch_assoc();
if ($row and password_verify($filtered_form['pass'], $row['pass']) {
$_SESSION['user'] = $row;
header("Location:index.php");
exit;
} else {
return "Incorrect password";
}
正如你所看到的,get_result()给你一个比 更好的结果(双关语不是故意的)store_result(),让你将用户信息存储在单个变量中,所以它不会乱七八糟的$_SESSION数组。
并被num_rows()证明是完全无用的(因为它总是发生)。
重要提示:您永远不应该以纯文本形式存储密码。始终支持哈希密码。
- 1 回答
- 0 关注
- 169 浏览
添加回答
举报