ajax status = 0

时间:2011-06-07 19:29:28

标签: javascript ajax status

我正在尝试从本地计算机上的远程服务器获取信息。 readyState没有问题,即== 4。但是,状态始终为0(而不是200) 当我按下按钮时,它什么也没有返回。

这是代码,:

<html>
<head>
<script type="text/javascript">
function loadXMLDoc()
{
var xmlhttp;
if (window.XMLHttpRequest)
  {// code for IE7+, Firefox, Chrome, Opera, Safari
  xmlhttp=new XMLHttpRequest();
  }
else
  {// code for IE6, IE5
  xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
  }
xmlhttp.onreadystatechange=function()
  {
  if (xmlhttp.readyState==4 && xmlhttp.status==200)
    {
    document.getElementById("myDiv").innerHTML=xmlhttp.responseText;
    }
  }
xmlhttp.open("GET",'http://www.spartanbook.com/textbooks_xml.asp?control=campus&campus=45&term=80',true);
xmlhttp.send();
}
</script>
</head>
<body>

<div id="myDiv"><h2>Let AJAX change this text</h2></div>
<button type="button" onclick="loadXMLDoc()">Change Content</button>

</body>
</html>

它基本上来自w3shcools。只需更换网址。 当我将其粘贴到浏览器的地址栏中时,我正在使用的网址正在运行。

有什么想法吗? 谢谢!

3 个答案:

答案 0 :(得分:6)

检查您是否未提出跨域请求。

例如,如果您没有从http://www.spartanbook.com提供此页面,则预期结果将被拒绝访问,这奇怪的是,readyState为4,但状态为0。

如果您需要提出跨域请求,则需要使用代理。

答案 1 :(得分:0)

此错误代码表示响应为空。看起来像防火墙问题

答案 2 :(得分:0)

就像Gavin所说,似乎您的问题是您正在制作跨域请求,由于安全原因,大多数浏览器会阻止该请求:http://en.wikipedia.org/wiki/Same_origin_policy

我建议您将代码从本地计算机移到满足“同源策略”的地方,如果您的情况在www.spartanbook.com上。

但是,问题有一种解决方法,那就是使用JSONP。这将允许您从另一个域上的程序中获取JSON数据。