我最近一直在尝试使用这个AJAX示例将表单数据与来自一个http://www.example.com域的SQL数据库进行比较。我的问题是readyState始终为1,而我的状态始终为0.预计分别为4和200。它也总是返回responseText =“”我看了整个StackOverflow,但没有成功找到任何有用的东西。
我对可能出现的问题感到困惑,但我似乎无法让它发挥作用。
*我也尝试在JS和PHP上设置文件权限,但功能相同。
*我正在使用专用的Web服务器来托管所有这些,我运行大多数脚本都没有问题。
// HTML GenerateRep.html
原谅缺乏<和>标签丢失,没有它们就不会出现代码。
form id="formgen" onsubmit="GenRep(this)"
....form stuff....
button id="submit" type="submit">Submit</button
// JAVASCRIPT GenerateRep.js
function GenRep(formgen) {
var email = formgen['repemail'];
var hash = formgen['reppass'];
var first = formgen['firstname'];
var last = formgen['lastname'];
var territory = formgen['territory'];
hash.value = CryptoJS.SHA256(hash.value);
var login = email + ";" + hash.value + ";" + first + ";" + last + ";" + territory;
Login(login);
}
function Login(login) {
var xhttp = new XMLHttpRequest();
xhttp.onreadystatechange = function() {
if (xhttp.readyState == 4 && xhttp.status == 200) {
if(xhttp.responseText == "VALID") {
window.location.href = "success.html";
} else if (xhttp.responseText == "INVALID") {
$("#login_error").text("Failed! Plese check your info.");
} else {
window.location.href = "error.php";
}
}
};
xhttp.open("GET", "Validate.php?q=" + login, true);
xhttp.send();
}
// PHP Validate.php
<?php
header('Access-Control-Allow-Origin: *');
include ("ConnectDB.php");
// Check connection
if ($conn->connect_error) {
die("Connection failed: " . $conn->connect_error);
}
//THIS IS A TEST TO SEE IF reponseText FUNCTIONS. IT DOES NOT.
//echo "testecho";
$whole = $_REQUEST['q'];
$userPass = explode (";", $whole);
$sql1 = "SELECT UName FROM Reps WHERE UName = '$userPass[0]'";
$result = $conn->query($sql1);
if ($result->num_rows > 0) {
$conn->close();
echo "INVALID";
} else {
$sql = "INSERT INTO Reps (UName, Pass, FName, LName, Territory) VALUES ('$userPass[0]', '$userPass[1]', '$userPass[2]', '$userPass[3]', $userPass[4])";
if ($conn->query($sql) === FALSE) {
$conn->close();
echo "Error: " . $sql . "<br>" . $conn->error;
}
$conn->close();
echo "VALID";
}
?>
答案 0 :(得分:0)
我以前&#34;评论&#34;而不是创建一个&#34;答案&#34;因为我没有建议修复,只是一个调试步骤,以确保你认为发生了什么,实际上正在发生。
由于我的建议帮助你解决了问题,我创建了这个&#34;答案&#34;如果你想给我&#34;信用&#34;。 : - )