3

我有以下功能:

$.ajax({url:"http://127.0.0.1:8080", data: "123",
    success:
    function(response, textStatus, jqXHR) 
    {
        alert(response);
    },
    error:
    function(jqXHR, textStatus, errorThrown)
    {
        alert("The following error occured: " + textStatus + " " + errorThrown);
    }
});

它发送请求,我用“nc -l 8080”拦截一个。看起来像

GET /?123 HTTP/1.1
Host: 127.0.0.1:8080
User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10.7; rv:15.0) Gecko/20100101         Firefox/15.0.1
Accept: */*
Accept-Language: en-us,en;q=0.5
Accept-Encoding: gzip, deflate
Connection: keep-alive
Origin: null

然后我回答

HTTP/1.1 200 OK
Content-Length: 3

abc

问题是我总是出错(“发生以下错误:错误”)你认为它可能有什么问题?

4

2 回答 2

0

正如 Tomasz 指出的那样,因为同源政策。

为了证明/测试这一点:

假设您的 html 页面是“index.html”,请执行以下操作。

  • 从与 index.html 相同的目录运行命令“python -m SimpleHTTPServer 8080”
  • 访问浏览器并输入“http://127.0.0.1:8080/index.html”。Python 应该为 html 提供服务,并且浏览器应该可以很好地呈现它。
  • 现在终止 python 命令并运行“nc -l 8080”。NC 已准备好在与原始网页相同的域/端口上处理 ajax 请求。
  • 现在只需从网页调用 ajax 调用,并用 nc 回复。

ajax 现在应该可以工作了。

于 2012-10-26T14:43:39.807 回答
0

readyState=0 表示请求还没有发送,常量“UNSENT”的名称:http: //www.w3.org/TR/XMLHttpRequest/

至于在发出请求之前导致错误的实际原因,是的,same-origin-policy 是最有可能的罪魁祸首。

您必须使用相对链接 url:"/" 我猜,来捕获请求。

于 2013-01-23T20:56:07.707 回答