为什么'\ n'被预先设置为我的HTTP(AJAX)responseText?

时间:2013-03-20 10:28:33

标签: php javascript ajax

这个特殊的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()方法中的包含类文件中,该方法最近已经更新,在开放<?之前在文件顶部包含一个换行符。

非常感谢大家的意见(如果没有它,我仍然会在客户端代码中摸索)!

1 个答案:

答案 0 :(得分:0)

我遇到了同样的问题并发现(通过向Ajax添加dataFilter选项,并显示返回的字符串化JSON),它确实是PHP脚本,它有语法问题。然后PHP服务器预先挂起HTML迷你文档以发出错误信号。但是,当回到AJAX时,由于dataType是'json',整个返回的PHP响应首先被json解析,从而剥离所有HTML前置并只留下换行符。在有效的JSON返回数据前面的这些新行导致JSON数据被视为语法错误,就是这样!使用dataFilter选项在警报中发送原始数据,我能够看到PHP脚本初始错误,并且一旦更正,就不会再添加新行了!