Подтвердить что ты не робот

Почему MSIE 8 сообщает код статуса HTTP 12150?

У меня возникли проблемы со странным кодом статуса HTTP в MSIE8.

Я отправляю HTTP GET по следующему URL-адресу:

 /cgi-bin/objectBrowser/snap.pl?file_key=28

Из Fiddler я вижу, что получаю следующий Raw-ответ:

HTTP/1.1 302 Found
Date: Fri, 27 May 2011 20:24:38 GMT
Server: Apache/2.2.3 (Red Hat)
Connection: close
Content-Type: text/html; charset=ISO-8859-1
Content-Length: 61

Location: /cgi-bin/objectBrowser/workWithSnap.pl?snapKey=32

Это было сгенерировано с использованием следующего Perl:

print $cgi->header( -status => '302 Found' );
print "Location: /cgi-bin/objectBrowser/workWithSnap.pl?snapKey=$snap_key\n\n";

Я использую jQuery для доступа к нему следующим образом:

jQuery.ajax({
    type : "GET",
    url : "/cgi-bin/objectBrowser/file.pl?pmr=" + request.pmr
        + "&filename=" + request.filename,
    statusCode : {
        200 : function(file_info) {
            if (file_info.status == "parsing") {
            jQuery('div#updates').append('<div class="information">No snap yet, but file <i>has</i> been registered already.</div>');
            jQuery('div#updates').append('<div class="waiting">Awaiting job completion...</div>');
            jQuery.getJSON("/cgi-bin/objectBrowser/job.pl?file_key=" + file_info.file_key, function(job_info) {
            poll_for_job_completion(job_info);
                });
            } else {
            jQuery.ajax({
                type : "GET",
            url : "/cgi-bin/objectBrowser/snap.pl?file_key=" + file_info.file_key,
        statusCode : {
                302 : function(xhr) {
                jQuery('div#updates').append('<div class="information">Redirecting to snap</div>');
                            alert("302: "+ xhr.responseText);
                process_302(xhr.responseText);
                }
                    }
            });
        }
        },
        302 : function(xhr) {
            alert("302: "+ xhr.responseText);
        process_302(xhr.responseText);
        },
        404 : register_file
    }
});

Наконец, для отладки у меня есть следующее:

jQuery('body').ajaxComplete(function(e,a,o) {
    console.log('Event: %o\nXHR: %o\nOptions: %o',e,a,o);
    console.log(o.url);
    console.log(a.status);
    console.log(a.responseText);
});

Все это прекрасно работает в Firefox и Chrome, но в MSIE, где я обычно получаю статус 302 в ответ на мой запрос для snap.pl, я получаю ответ 12150. Лучший удар, который я нашел, находится на MSDN, что говорит о том, что это ERROR_HTTP_HEADER_NOT_FOUND... но заголовки выглядят хорошо для меня.

Я не могу понять, что здесь не так. Кто-нибудь видит что-то, что я могу игнорировать?

4b9b3361

Ответ 1

Проблема решена!

Ошибка была генерация заголовка.

Полученный HTTP-заголовок имеет большой пробел в нем, а MSIE8 интерпретирует Location как находящийся в теле, а не в заголовке.

Используя

print $cgi->redirect( -uri =>  "/cgi-bin/objectBrowser/workWithSnap.pl?snapKey=$snap_key");

заголовок создается правильно, и я снова получаю разумное поведение.

HTTP/1.1 302 Found
Date: Fri, 27 May 2011 21:00:51 GMT
Server: Apache/2.2.3 (Red Hat)
Location: /cgi-bin/objectBrowser/workWithSnap.pl?snapKey=32
Content-Length: 0
Connection: close
Content-Type: text/plain; charset=UTF-8