我似乎无法弄清楚为什么这不起作用或找到相关文章。我可以看到firebug中的json对象返回成功:false或成功:来自post请求的true,所以我不知道为什么函数不会被激活。
AJAX
$("#login").submit(function (e) {
e.preventDefault();
$.ajax({
url: "../process/login-process.php",
type: "POST",
contentType: "application/json; charset=utf-8",
data: { 'username': $('[name=username]').val(), 'password': $('[name=password]').val() },
beforeSend : function (){
//$("#login").hide();
},
success: function(data){
window.localation=data.redirect;
},
error: function(data) {
$(".error").html('');
alert('wtf');
if(data.empty) {
$(".error").html(data.empty);
}
if(data.incorrect) {
$(".error").html(data.incorrect);
}
}
});
});
php
<?php
session_start();
include "../inc/connect.php";
$username = mysqli_real_escape_string($con, $_POST['username']);
$password = mysqli_real_escape_string($con, $_POST['password']);
$password = hash('sha256', $password);
$sql = "SELECT * FROM admin WHERE username ='$username' AND password ='$password'";
$result = mysqli_query($con, $sql) or die(mysqli_error($con));
$row = mysqli_fetch_array($result);
$count=mysqli_num_rows($result);
if ($username == "" || $password == "") {
$data['empty'] = 'All fields are required.';
} else if(($count==1) && ($username)) {
$_SESSION['user'] = $row['firstName'];
$_SESSION['userID'] = $row['adminID'];
$data['success'] = true;
$data['redirect'] = '../pages/dashboard.php';
} else {
$data['success'] = false;
$data['incorrect'] = "Incorrect Username or Password.";
}
echo json_encode($data);
?>
答案 0 :(得分:1)
您需要在代码中纠正两件事,
window.localation
回拨window.location
更改为success
dataType: 'JSON'
或在成功回调中使用$.parseJSON
所以,你的成功回调应该是:
success: function(data){
data = $.parseJSON(data); // <- Don't use this if you add dataType: 'JSON' in ajax
window.location=data.redirect; //<- Spelling corrected for location
}
答案 1 :(得分:0)
你发送的是一个字符串(在这种情况下是一个json),没有提到任何标题。所以它总是200好。
因此,错误永远不会发生。
success: function(data){
window.localation=data.redirect; <----- error here. location
},
这就是为什么没有发生的事情。
在数据不正确的情况下触发错误
而不是:
} else {
$data['success'] = false;
$data['incorrect'] = "Incorrect Username or Password.";
}
使用
} else {
header('HTTP/1.0 403 Forbidden');
echo 'Incorrect Username or Password.';
exit;
}
这会给你一条403禁止的消息。