Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Cross-origin Ajax requests don't work in Opera and IE9?

I am using this page - http://ecmazing.com/cors.html - to make a cross-origin Ajax request to this resource: http://hacheck.tel.fer.hr/xml.pl

It works in Chrome, Safari and Firefox, but doesn't in IE9 and Opera.

The code:

var pdata = {'textarea': 'test'};

$.post('http://hacheck.tel.fer.hr/xml.pl', pdata, function(data, status, xhr) {
    output.value = xhr.responseText;
});

(The expected result is an XML code string.)

See for yourself: http://ecmazing.com/cors.html

In IE9 and Opera, the error handler of the XHR object executes and this error object is passed in:

{
    readyState: 4,
    status: 0,
    statusText: 'error'
}

As you can see, this error object doesn't reveal much information.

How can I make it work in IE9 and Opera?

like image 888
Šime Vidas Avatar asked Aug 04 '11 20:08

Šime Vidas


2 Answers

See the entry for cors at whencaniuse.

For Internet Explorer CORS is "Supported somewhat in IE8 and IE9 using the XDomainRequest object", so you need to use an alternate object to use it.

Opera simply doesn't support it.

If you need cross-domain Ajax in Opera, then use JSON-P.

like image 165
Quentin Avatar answered Nov 15 '22 21:11

Quentin


I got so frustrated trying to use CORS with IE and jQuery, I wrote a library to smooth over the worst parts.

Yeah, Microsoft's shortage of cash and manpower have kept them from making their browsers properly CORS-compliant in the seven short years they've had to do it in, but I still prefer CORS to JSONP, which, frankly, is a hack.

like image 28
Michael Lorton Avatar answered Nov 15 '22 20:11

Michael Lorton