【问题标题】:How do I send an AJAX request on a different port with jQuery?如何使用 jQuery 在不同的端口上发送 AJAX 请求?
【发布时间】:2011-01-07 04:03:41
【问题描述】:

我需要将 AJAX 请求发送到例如运行守护程序的端口 8080。

【问题讨论】:

    标签: javascript jquery ajax cross-domain


    【解决方案1】:

    这打破了Same origin policy。即使使用同一个域,您也不能使用不同的端口。

    您可以按照Doug 的建议使用 JSONP。

    或者,作为另一种可能的解决方法,您可以设置一个非常简单的reverse proxy(如果您使用的是 Apache,则使用mod_proxy)。这将允许您在 AJAX 请求中使用相对路径,而 HTTP 服务器将充当任何“远程”位置的代理。

    mod_proxy 中设置反向代理的基本配置指令是ProxyPass。您通常会按如下方式使用它:

    ProxyPass     /ajax/     http://www.localhost:8080/
    

    在这种情况下,您将使用 jQuery 请求 /ajax/test.xml,但实际上服务器会通过在内部充当 http://www.localhost:8080/test.xml 的代理来提供此服务。

    如果您使用的是 IIS,您可能希望使用 Managed Fusion URL Rewriter and Reverse Proxy 来设置反向代理。

    【讨论】:

    • +1 获得出色的答案。我回答了书面的“blah blah blah”罐头回复,您提供了一个非常可行的解决方案。谢谢丹尼尔!
    • 哦,proxy会在服务器端造成额外的处理。所以我会选择jsonP
    • 在我发现这个之前,我一直在四处寻找,试图找出为什么我不能跨端口发布数据。谢谢大佬。
    • 嘿,CORS 呢?
    【解决方案2】:

    您不能POST 信息跨域、子域或端口号。但是,如果您可以访问守护程序 请求站点,则可以使用 JSONP。如果需要返回数据,则daemon 需要支持callback 查询参数并以正确的格式返回。

    将信息传递给守护进程:

    $.getJSON('http://domain.com:8080/url/here?callback=?', {
      key: 'value',
      otherKey: 'otherValue'
    }, function(data){
         // Handles the callback when the data returns
    });
    

    现在只需确保您的守护进程处理callback 参数。例如,如果callback=mycallback 来自守护进程的返回(写入页面的唯一内容)应该如下所示:

    对于键/值对:

    mycallback( {'returnkey':'returnvalue', 'other':'data' });
    

    对于数组:

    mycallback( [1,2,3] );
    

    如果您没有 JSONP 或类似机制,则无法使用 jQuery 进行跨域通信。

    【讨论】:

    • 有没有通用的方法来替换domain.com?这样只能在生产环境中使用,因为我在开发环境中使用localhost
    • 您应该能够使用'http://' + window.location.hostname + ':8080/url' 构建在本地和在线都可以使用的 URL。
    【解决方案3】:

    这算作不同的来源,即使您将它放在同一个盒子上,只是端口不同。

    如果您主要针对 FireFox 3.5 及更高版本等新浏览器,您可以尝试将 Access-Control 标头添加到另一个端口的应用程序中,并允许从您的默认应用程序池调用。有关访问控制标头的信息可以在这里找到:https://developer.mozilla.org/en/HTTP_access_control

    IE 也实现了它(同样,在使用不同的 ACTIVEX 控件时,为什么会这样?):http://blogs.msdn.com/ie/archive/2009/01/14/completing-access-control-support-for-xdomainrequest.aspxhttp://msdn.microsoft.com/en-us/library/cc288060(VS.85).aspx

    【讨论】:

      猜你喜欢
      • 2019-12-11
      • 2017-01-14
      • 2016-10-02
      • 1970-01-01
      • 2023-04-07
      • 1970-01-01
      • 2020-06-30
      • 2011-06-13
      • 2015-06-27
      相关资源
      最近更新 更多