AJAX / PHP / JS readyState = 1和Status = 0总是。没有回复文字

时间:2015-10-20 16:50:35

标签: javascript php ajax

我最近一直在尝试使用这个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";

}
?>

1 个答案:

答案 0 :(得分:0)

我以前&#34;评论&#34;而不是创建一个&#34;答案&#34;因为我没有建议修复,只是一个调试步骤,以确保你认为发生了什么,实际上正在发生。

由于我的建议帮助你解决了问题,我创建了这个&#34;答案&#34;如果你想给我&#34;信用&#34;。 : - )