我一直在寻找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
答案 0 :(得分:0)
JSON看起来很简单。我猜调用或返回值有问题。
同时检查status
和responseType
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服务器后,问题就解决了。
感谢大家帮助我解决这个问题。