这个特殊的 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() 方法中包含的一个包含类文件中,该方法最近已更新为在打开之前在文件顶部包含一个换行符<?
。
非常感谢大家的投入(如果没有它,我仍然会在客户端代码中摸索)!