这个特殊的AJAX调用在responseText返回的值前面返回“\ n”。
之前没有这样做,现在当我测试带有if (request.responseText == 100)
的有效返回代码时,它失败了,因为它现在等于“\ n100”。
我知道我可以剥离“\ n”,但这将是一种解决方法,我宁愿找到原因并修复它。
这是我的客户端代码:
function AJAX(){
var xmlHttp;
try{
xmlHttp=new XMLHttpRequest(); // Firefox, Opera 8.0+, Safari
return xmlHttp;
}
catch (e){
try{
xmlHttp=new ActiveXObject("Msxml2.XMLHTTP"); // Internet Explorer
return xmlHttp;
}
catch (e){
try{
xmlHttp=new ActiveXObject("Microsoft.XMLHTTP");
return xmlHttp;
}
catch (e){
alert("Your browser does not support AJAX!");
return false;
}
}
}
}
function logDetails() {
var request,
Result = document.getElementById('Result'),
message = document.getElementById('message'),
url = 'ajax/login.user.php?',
us = document.getElementById('username').value,
pa = document.getElementById('password').value;
Result.innerHTML = 'Logging in...';
if (document.getElementById) {
request = AJAX();
}
if (request) {
request.onreadystatechange = function() {
if (request.readyState == 4 && request.status == 200) {
var r = request.responseText;
//var r = 100;
if (r == '100') {
Result.innerHTML = 'You are now logged in.';
window.location.href = "prebooks.php";
}
else if (r == '101' || r == '102') {
Result.innerHTML = 'Your login attempt failed.';
resetDetails();
}
else if (r == '103') {
Result.innerHTML = 'Sorry, you have no books subscription.';
}
else if (r == '999') {
Result.innerHTML = 'You have no more attempts!';
message.innerHTML = 'Please call us on (02) XXXXXXX so that we can assist you.';
} else {
alert(r);
}
}
};
}
// add my vars to url
url += "arg1="+us+"&arg2="+pa;
request.open("GET", url, true);
request.send(null);
}
这是我的服务器端代码:
<?= 100 ?>
好的,我简化了它,但我试过直接回复'100'并且问题仍然存在。
更新 我错了,直接回应'100'并没有解决问题。确实如此。对此感到抱歉,感谢您指点我正确的方向。
然而,这确实让我试图找出服务器端的输出是如何被污染的。
在服务器端,我有一个处理身份验证的类,并返回一个值(100)进行回显。这是一行:
echo $L->doLogin($pkg);
与doLogin()
方法中的返回相关的行是:
$pkg[status]=100;
return $pkg[status];
为了确保换行符在某些地方没有泄露,如果我将echo $L->doLogin($pkg);
替换为echo 100;
则可行。
更新2 - 已解决
事实证明,问题出在一个包含在doLogin()方法中的包含类文件中,该方法最近已经更新,在开放<?
之前在文件顶部包含一个换行符。
非常感谢大家的意见(如果没有它,我仍然会在客户端代码中摸索)!
答案 0 :(得分:0)
我遇到了同样的问题并发现(通过向Ajax添加dataFilter选项,并显示返回的字符串化JSON),它确实是PHP脚本,它有语法问题。然后PHP服务器预先挂起HTML迷你文档以发出错误信号。但是,当回到AJAX时,由于dataType是'json',整个返回的PHP响应首先被json解析,从而剥离所有HTML前置并只留下换行符。在有效的JSON返回数据前面的这些新行导致JSON数据被视为语法错误,就是这样!使用dataFilter选项在警报中发送原始数据,我能够看到PHP脚本初始错误,并且一旦更正,就不会再添加新行了!