Mam ogromny problem z którym nie mogę sobie poradzić. Przeszukałem zakamarki internetu, znalazlem wiele solucji, ale żadna dla mnie nie zadziałała.
Mam nadzieję, że tu znajdę odpowiedź.
Sprawa polega na wczytaniu przy pomocy AJAX danych z pliku w innej subdomenie. Pod wszystkimi przeglądarkami działa. Nawet w IE10 działa. Problem natomiast jest z przeglądarką IE9.
Poniżej zamieszczam wgląd w pliki:
Plik który próbuje odebrać dane. http://sub1.mydomain.pl/testAjax.php
Kod
<html>
<head>
<script src="public/js/jquery.js" type="text/javascript"></script>
<script>
$(document).ready(function(){
$.support.cors = true;
vars = {done:"My data"}
$.ajax({
type: "POST",
url: 'http://sub2.mydomain.pl/test.php',
cache: false,
dataType : 'html',
data : vars,
crossDomain: true
}).done(function(data) {
$('#result').append('Response from server: <br />' + data + '<br />');
}).fail(function(jqXHR, errorText){
$('#result').append('readyState: ' + jqXHR.readyState + '<br />');
$('#result').append('responseText: ' + jqXHR.responseText + '<br />');
$('#result').append('status: ' + jqXHR.status + '<br />');
$('#result').append('textStatus: ' + errorText + '<br />');
});
});
</script>
</head>
<body>
<div id="result"></div>
</body>
</html>
<head>
<script src="public/js/jquery.js" type="text/javascript"></script>
<script>
$(document).ready(function(){
$.support.cors = true;
vars = {done:"My data"}
$.ajax({
type: "POST",
url: 'http://sub2.mydomain.pl/test.php',
cache: false,
dataType : 'html',
data : vars,
crossDomain: true
}).done(function(data) {
$('#result').append('Response from server: <br />' + data + '<br />');
}).fail(function(jqXHR, errorText){
$('#result').append('readyState: ' + jqXHR.readyState + '<br />');
$('#result').append('responseText: ' + jqXHR.responseText + '<br />');
$('#result').append('status: ' + jqXHR.status + '<br />');
$('#result').append('textStatus: ' + errorText + '<br />');
});
});
</script>
</head>
<body>
<div id="result"></div>
</body>
</html>
Plik który AJAX odpytuje. http://sub2.mydomain.pl/test.php
Kod
<?php
header("Access-Control-Allow-Origin: *");
echo "Connection: Works!<br />";
echo "Data sent: ".$_POST['done'];
?>
header("Access-Control-Allow-Origin: *");
echo "Connection: Works!<br />";
echo "Data sent: ".$_POST['done'];
?>
Jak pisałem wyżej. Wszystko działa wszędzie jak trzeba orpócz IE9.
O to co powinno się wyświetlić:
Response from server:
Connection: Works!
Data sent: My data
A w IE9 dostaje takie dane:
readyState: 0
responseText: undefined
status: 0
textStatus: error
Może ktoś spotkał się z podobnym problemem.
Aha dodam jeszcze, że używam jQuery w wersji 1.9.1