【发布时间】:2018-09-11 06:28:52
【问题描述】:
我正在尝试为网站制作登录页面。我有一个使用 AJAX 向 PHP 脚本发送请求以检查是否输入了正确的用户名和密码的函数。如果查询返回成功结果,我发送 http_response_code(200),否则我发送 http_response_code(403) .但是,登录功能似乎没有返回任何响应状态。响应似乎未定义。在这种情况下,即使输入了正确的密码和用户名,该功能也会为我提供错误密码或用户名的窗口警报。我应该检查什么条件才能根据 http 响应代码确定成功函数应该做什么?是否有另一种方法可以根据 PHP 脚本的作用向 AJAX 返回条件?
这里是登录功能的代码。
function login(){
var username = document.getElementById("username").value;
var password = document.getElementById("password").value;
var dataString = 'username1=' + username + '&password1=' + password;
if (username == '' || login == ''){
window.alert("Please fill in username or password.");
}
else{
$.ajax({
type: "POST",
url: "login.php",
data: dataString,
cache: false,
crossDomain : true,
success: function(response) {
if (response.status == 200) {
window.location = 'http://localhost/site.html';
}
else {
window.alert("The password or username you have entered is not valid");
}
}
});
}
return false;
}
这是我的 php 脚本。
<?php
header('Access-Control-Allow-Origin: *');
header('Access-Control-Allow-Methods: GET, POST, PATCH, PUT, DELETE, OPTIONS');
header('Access-Control-Allow-Headers: Origin, Content-Type, X-Auth-Token');
$password2 = $_POST['password1'];
$username2 = $_POST['username1'];
$connection = mysqli_connect("localhost", "root", "password", "database") or die("Unable to connect to MySQL");
$query = mysqli_query($connection, "SELECT * FROM users where username = '$username2' AND password = '$password2'") or die(mysqli_error($connection));
$row = mysqli_fetch_array($query, MYSQLI_BOTH) or die(mysqli_error($connection));
if(!empty($row['username']) AND !empty($row['password'])) {
session_start();
$_SESSION['username'] = $username2;
http_response_code(200);
echo "Successful Login";
exit;
}
else{
http_response_code(403);
echo "The password or username you have entered is not valid";
}
mysqli_close($connection);
?>
【问题讨论】:
-
你的意思是“返回”,对吧?
-
请使用 PDO 或其他为您准备好的语句。您的代码易受 SQL 注入攻击。
-
response不是对象/数组...这不是您检查response.status的方式 -
更改 var dataString = 'username1=' + 用户名 + '&password1=' + 密码;到 var dataString = {username1 : username,password1:password};
-
我认为 403 响应永远不会触发 ajax 的成功函数,您最好添加一个失败处理程序,或者查看 statusCode 属性为各种响应代码构建自定义处理程序。跨度>
标签: javascript php ajax