php - 检查登录用户名和密码
问题描述
我试图在不离开页面的情况下根据我的数据库验证用户的信息,并且只有当信息正确时,它才应该离开页面并将用户路由到用户门户。PHP 工作正常,它检查信息,如果正确将用户路由到门户,如果错误则路由到空页面。
我要做的是拦截提交,根据数据库验证它,如果错误则输出错误消息,如果正确则路由用户。
我认为我面临的错误是如何让 PHP 以某种方式向 jQuery “信号”它是错误的
我创建了一个提交处理程序,它停止提交表单,然后将其序列化并将其发送到 checkLogin.php,但之后我没有得到任何结果。
如果信息正确,我没有将用户发送到任何地方,因此如果用户名和密码正确,预计不会发生任何事情
这是 checkLogin.php - DB 替换为连接的实际数据库,我不在本地主机上托管,所以信息是私有的
<?php
$link = mysqli_connect('DB', 'DB', 'DB', 'DB'); //Database Connection
if (!$link) {
die('Could not connect: ' . mysql_error());
}
$username = mysqli_real_escape_string($link, $_POST['username']); //Retrieving the username
$password = mysqli_real_escape_string($link, $_POST['password']); //Retrieving the password
$user_sql = "SELECT username FROM login WHERE username = '$username'"; //Setting the SQL query
$user_check = mysqli_query($link, $user_sql); //Putting the result of the query (^) into a variable
if ($user_check) {
$test = "THIS WAS A SUCCESS";
} else {
$test = "THIS WAS A FAILURE";
}
?>
这是 login.js 中的函数 - 在用户单击提交后调用该函数
function checkLogin() {
$("#login_form").submit(function(event) { //Submit Handler
var post = $.post("checkLogin.php", $form.serialize());
post.done(function() { //When the function is successfully submitted
});
//$("#login_form").submit(); //Submit the form (blocked for now)
});
}
login.html - 表单
<form action="login.php" method="post" name="login_form" id="login_form">
<div class="loginTitle">Client Login</div>
<div class="loginLabel">Username: <span id="userError"><?php echo $test ?></span></div>
<input type="text" name="username" class="loginBox" id="userName">
<div class="loginLabel">Password: <span id="passError"></span></div>
<input type="password" name="password" class="loginBox" id="passWord">
<br>
<input type="checkbox" name="rememberMe" value="rememberMe" id="remMe">Remember me for next time
<br>
<input type="submit" value="Login" name="submit" id="submit">
</form>
login.html - 在顶部
<?php
include ("checkLogin.php");
?>
预期:当我输入错误的用户名时,表单标签旁边应该会显示“这是失败”
实际:无
解决方案
推荐阅读
- java - 如何解析mif文件?
- javascript - 动态表单提交重新加载页面而不是调用 ngSubmit 函数
- ios - 从 iOS 应用程序检测到 iCloud 的不可访问性
- woocommerce - 使用交叉销售产品在 WooCommerce 感谢页面上追加销售
- canvas - 软件渲染和gpu渲染有什么区别
- terraform - 如何在 terraform EC2 启动模板用户数据中使用模板文件?
- antlr - 在 C++ 中使用访问者模式访问 antlr4 可选终端
- c - for循环中的indexNumber不增加
- c++ - 枚举类型的运算符重载
- json - 如何在 shell 脚本中使用 jq 替换整个数组?