Json调用JSON.parse:意外结束数据

时间:2013-02-01 14:07:34

标签: php ajax json

我一直在寻找stackoverflow来解决我的问题,但我似乎无法找到原因。

我创建了一个返回JSON对象的Web服务器:

http://213.125.101.19/api.php?function=test

之后,我使用以下javascript创建了一个HTML文件,以使用Ajax调用JSON

<script language="javascript" type="text/javascript">
    <!-- 
    //Browser Support Code
    function ajaxCall(){
        var ajaxRequest;  // The variable that makes Ajax possible!

        try{
            // Opera 8.0+, Firefox, Safari
            ajaxRequest = new XMLHttpRequest();
        } catch (e){
            // Internet Explorer Browsers
            try{
                ajaxRequest = new ActiveXObject("Msxml2.XMLHTTP");
            } catch (e) {
                try{
                    ajaxRequest = new ActiveXObject("Microsoft.XMLHTTP");
                } catch (e){
                    // Something went wrong
                    alert("Your browser broke!");
                    return false;
                }
            }
        }

        // Create a function that will receive data sent from the server
        ajaxRequest.onreadystatechange = function(){
            if(ajaxRequest.readyState == 4){
                var response = ajaxRequest.responseText;
                obj = JSON.parse(response);
                console.log(obj);

                if(response.indexOf("Fatal error")>=0){
                    alert('Error, Try again.');
                }else{
                    document.getElementById("response").value = response;               
                }                 

            }   
        }


            ajaxRequest.open("GET", "http://213.125.101.19/api.php?function=test", true);
            ajaxRequest.send(null); 
    }
    </script>

当我运行此代码时,我的Firebug返回

“SyntaxError:JSON.parse:意外的数据结束 obj = JSON.parse(response);“

如果我通过验证器运行我的JSON,一切似乎都没问题。

任何想法如何解决这个问题?

亲切的问候, Luuk

2 个答案:

答案 0 :(得分:0)

JSON看起来很简单。我猜调用或返回值有问题。

同时检查statusresponseType

ajaxRequest.onreadystatechange = function(){
    if(ajaxRequest.readyState == 4){
        console.log('status=' + ajaxRequest.status +
                    ', statusText=' + ajaxRequest.statusText +
                    ', responseType=' + ajaxRequest.responseType +
                    ', responseText=' + ajaxRequest.responseText);
...
}

答案 1 :(得分:0)

此问题的问题在于我的HTML请求是从另一台PC发送到我的网络服务器。

@Olaf Dietsche说检查ajaxrequest状态是个好主意。这给出了0,这不是成功的反应。

将html请求文件复制到Web服务器后,问题就解决了。

感谢大家帮助我解决这个问题。