所以基本上我要做的是验证登录提交时的密码匹配。但它失败了......在注册提交时,我使用crypt()来管理用户密码,并且它可以毫无问题地存储到数据库中。
我的数据库有一个表用户,包含6行 ID / 名称 / 姓氏 / 登录 / 密码 / 电子邮件
在登录提交时,我检查用户是否存在登录并成功然后检查密码,这里是失败的地方,我不知道问题出在哪里,因为我已经在另一台服务器上测试了一次这个脚本并且它工作了...魔术发生......任何帮助都会受到赞赏,也许是我可以优化的东西,或者是我在做错的同时复制/粘贴其他文件中的代码而我看不到它
的login.php
<?php
session_start();
require ('./include/connect.php');
if(isset($_POST['logBtn']))
{
$login = mysqli_real_escape_string($connect, $_POST['login']);
$pass = mysqli_real_escape_string($connect, $_POST['pass']);
$sql = "SELECT * FROM `users` WHERE `Login` = '".$login."'";
$result = mysqli_query($connect, $sql);
$row = $result->fetch_array();
$db_pass = $row['Password'];
$hashed_pass = crypt($pass, $db_pass);
if($result->num_rows > 0)
{
if($hashed_pass == $db_pass)
{
echo "<script>alert('You have successfully logged in!')</script>";
echo "<script>window.open('welcome.php','_self')</script>";
$_SESSION['user'] = $login;
}
else
{
echo "<script>alert('Wrong login or password!')</script>";
}
}
else
{
echo "<script>alert('No users with such login found in the database!')</script>";
}
}
mysqli_close($connect);
?>
<!DOCTYPE html>
<html>
<body>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>Login</title>
<link rel="stylesheet" type="text/css" href="css/style.css">
<script src="./scripts/go_back.js"></script>
</head>
<div class="login">
<form action="login.php" align="center" method="post">
<br>
<input type="text" name="login" placeholder="Login" required oninvalid="this.setCustomValidity('Enter login!')" oninput="setCustomValidity('')" />
<br><br>
<input type="password" name="pass" placeholder="Password" required oninvalid="this.setCustomValidity('Enter password!')" oninput="setCustomValidity('')" />
<br><br>
<button class="back_btn" onclick="goBack()">Go back</button>
<input class="login_btn" type="submit" name="logBtn" value="Log In">
<br><br>
</form>
<a href="register.php"><button class="no_acc_btn">I do not have an account</button></a>
</div>
</body>
</html>
答案 0 :(得分:0)
获取数据库:
SELECT COUNT(*) FROM USERS WHERE LGIJ = ? AND PASSWORD = f(?)
其中f()
是您用于存储密码的数据库函数。如果结果为1,则有这样的用户:如果为零,则不存在
但不要加密密码。有company-breaking legal reasons为什么不呢。使用哈希函数和盐。