IE中的跨域jquery ajax请求xDomain请求不起作用

时间:2013-01-10 06:33:34

标签: internet-explorer jquery

我使用以下代码在IE中使用xDomain Request创建跨域jquery ajax请求。

var xdr;  
 var URL=parentDomain+"/chat/getmessagesservlet";

 if (jQuery.browser.msie && window.XDomainRequest) {  

   // Use Microsoft XDR
   var xdr = new XDomainRequest();
    xdr.open("POST", URL + '?to='+chatboxtitle+'&yourName='+myName+'&chatBoxIndex='+tabIncr);
    xdr.onload = function () {
   var dom  = new ActiveXObject("Microsoft.XMLDOM");
   dom.async = false;
  JSON = $.parseJSON(xdr.responseText); 
   if (JSON == null || typeof (JSON) == 'undefined') {
    JSON = $.parseJSON(data.firstChild.textContent);   
   }

    processData(JSON); // internal function
   }; 

   xdr.onerror = function() {
     _result = false;    
    };
   xdr.send();

    } else {
    $.ajax({ 
      type: 'POST', 
       url: URL,   
          processData: true,
          data: {'to':chatboxtitle,'yourName':myName,'chatBoxIndex':tabIncr}, 
           dataType: "json",
          async: false,
          success: function (data) {
            processData(data);   
           }
});

}'

我也在服务器端设置标题如下:

response.setHeader("Access-Control-Allow-Origin","*");   
response.setHeader("Content-Type","text/plain");
response.setHeader("Access-Control-Allow-Methods"," GET, POST");
response.setHeader("Access-Control-Allow-Headers", "Content-Type"); 

但在IE8& IE9它无法正常工作。 ResponseText返回null或为空。 我已经看到使用jQuery

.ajaxTransport( dataType, handler(options, originalOptions, jqXHR)

.ajaxPrefilter( [dataTypes ], handler(options, originalOptions, jqXHR) )

可以进行跨域请求。但我不知道如何在我的代码中使用它。 选项中传递的值是什么? originalOptions参数? 请给我指导解决这个问题。

1 个答案:

答案 0 :(得分:0)

这可能会有所帮助:

xdr.onprogress = function () { }; //Needed to save IE9 from melting.