jquery氛围跨域限制

时间:2011-09-18 14:42:29

标签: jquery cross-domain jsonp comet atmosphere

我想使用jquery氛围插件连接到彗星服务器。问题是服务器位于不同的域上并且“从v.7.2开始,Atmosphere JQuery PubSub不支持跨域请求。我们不能将此方法用于JSONP”。有没有办法绕过这个?我愿意接受任何解决方案!

以下是远程域上给定示例页面中使用的javascript代码:

    $(document).ready(function() {

    function callback(response) {
        // Websocket events.
            $.atmosphere.log('info', ["response.state: " + response.state]);
        $.atmosphere.log('info', ["response.transport: " + response.transport]);

        detectedTransport = response.transport;
        $('ul').append($('<li></li>').text("Resp Status : "+response.status+" Transport : "+response.transport));
        if (response.transport != 'polling' && response.state != 'connected' && response.state != 'closed') {
        $.atmosphere.log('info', ["response.responseBody: " + response.responseBody]);
        if (response.status == 200) {
            var data = response.responseBody;
            if (data.length > 0) {
               dataArray = eval("("+data+")");

               $.each(dataArray, function(index, value){
                 var output = '';
                 var dipData = value;
                 for (property in dipData) {
                    output += property + ': ' + dipData[property]+'; ';
                 }

                 $('ul').append($('<li></li>').text(dipData.__publicationName+":"+output));
               });
            }
        }
        else{

        }
        }
    }

       // As of v 0.7.2, Atmosphere JQuery PubSub does not support
       // cross domain requests. We cannot use this method for JSONP
       $.atmosphere.subscribe(document.location.toString() + 'webcast', callback);
    });

由于

2 个答案:

答案 0 :(得分:1)

最简单的选择可能是在您的域上建立Node.js代理以将您的请求代理到外部域。

答案 1 :(得分:0)

最简单的解决方案是:在没有IE浏览器和XDR或跨域请求时使用CORS。 您只需修改HTTP标头并使用Allow_Access。