如何在服务器端回答ajax请求?

时间:2012-10-21 11:38:35

标签: javascript ajax http netcat

我有以下功能:

$.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

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

2 个答案:

答案 0 :(得分: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现在应该可以工作了。

答案 1 :(得分:0)

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

关于发出请求之前的错误的实际原因,是的,同源政策是最可能的罪魁祸首。

你必须使用相对链接,url:“/”我猜,要捕获请求。

相关问题