[英]AJAX status 200 fires error on PHP echo of json_encode
使用以下程序,一切正常,但會引發AJAX錯誤:
javascript:
var data = {
email: 'me@gmail.com',
password: 'secretword'
};
$.ajax({
type: "POST",
dataType: "application/json",
url: "http://localhost/CFBserver/validateUser.php",
data: data,
success: function (response) {
console.log(response.responseText);
},
error: function (response) {
console.log(response.responseText);
}
});
}
的PHP:
<?php
$conn = mysqli_connect('localhost', 'root', '', 'cfbdata');
if (mysqli_connect_errno($conn)) {
echo "Failed to connect to MySQL: " . mysqli_connect_error();
}
$email = filter_input(INPUT_POST, 'email', FILTER_SANITIZE_STRING);
$password = filter_input(INPUT_POST, 'password', FILTER_SANITIZE_STRING);
$sql = "SELECT * FROM users WHERE email = '$email' AND password = '$password'";
if (!mysqli_query($conn, $sql)) {
die('Error: ' . mysqli_error($conn));
}
$result = mysqli_query($conn, $sql);
$numrows = mysqli_num_rows($result);
if ($numrows > 0) {
$message = array('result' => 'found',
'email' => $email,
'password' => $password,
);
} else {
$message = array('result' => 'Not found',
'email' => $email,
'password' => $password,
);
}
header('Content-type: application/json');
echo json_encode($message);
mysqli_close($conn);
?>
這是控制台顯示的內容:
<html>
<head>
<meta charset="UTF-8">
<title></title>
</head>
<body>
{"result":"found","email":"me@gmail.com","password":"secretword"}
</body>
</html>
因此,php在mysql數據庫中找到記錄,但返回AJAX時,會引發錯誤。 為什么是這樣?
您的AJAX期待JSON響應,但獲取HTML。 這就是為什么請求返回狀態代碼200(= OK),但是您的JS無法使用的原因。
PHP的json_encode
本身不會添加HTML,因此您可能正在輸出到模板(或者您已將PHP封裝為HTML)。
正如其他人也提到的那樣,您可以進行SQL注入 。 也沒有辦法確保您的錯誤方法正在觸發,因為您的AJAX error
和success
都做同樣的事情。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.