Почему мой запрос на перекрестную доменную почту предварительно запрашивается запросом параметров?
Вопрос
По данным Центра разработчика Mozilla Control Access Control. Статья, перекрестные запросы на сайт могут быть «простыми» - т. Е. Не требуют предварительной податки - если тип контента запроса application/x-www-form-urlencoded
.
Я не получаю это поведение в Firefox, и я совсем не понимаю, почему это так. Вот мой код настройки:
function makeXDomainRequest(url, method, data) {
var req =
typeof XDomainRequest !== "undefined" ?
new XDomainRequest() : new XMLHttpRequest();
req.open(method || "GET", url, true);
if (typeof req.onload !== "undefined") {
req.onload = onResponseLoad;
req.onerror = onRequestError;
} else {
req.onreadystatechange = onRequestStateChange;
}
if (data && typeof req.setRequestHeader === "function") {
req.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
} else {
// no way to set Content-Type req header in IE's XDomainRequest:
// http://blogs.msdn.com/b/ieinternals/archive/2010/05/13/xdomainrequest-restrictions-limitations-and-workarounds.aspx
}
req.send(data || null);
}
function onResponseLoad() {
alert("Response!\n" + this.responseText);
}
function onRequestError(args) {
alert("Error!");
}
function onRequestStateChange() {
if (this.readyState === 4) {
if (this.status === 200) {
onResponseLoad.apply(this);
} else {
onRequestError.apply(this);
}
}
}
И вот сервер, который я пинга:
// thanks to http://saltybeagle.com/cors/ for having this demo endpoint:
var URL = "http://ucommbieber.unl.edu/CORS/cors.php";
Теперь, если я сделаю простую почту запрос - с данными, отправленными как application/x-www-form-urlencoded
В указанном выше коде - запрос предварительно заправляется в Firefox с запросом параметров. Это не предварительно довольствовано в хроме. Откройте Fiddler, прежде чем запустить это, чтобы увидеть сами:
makeXDomainRequest(URL, "POST", "name=foobar");
// alerts "Response! Hello CORS [...] You sent a POST request. Your name is foobar"
Вот запрос параметров предварительного производителя в Fiddler (обратите внимание на Access-Control-Request-Method: POST
Заголовок, даже если я указал предположительно безопасный тип контента и никаких пользовательских заголовков):
OPTIONS http://ucommbieber.unl.edu/CORS/cors.php HTTP/1.1
Host: ucommbieber.unl.edu
User-Agent: Mozilla/5.0 (Windows; U; Windows NT 6.1; en-US; rv:1.9.2.8) Gecko/20100722 Firefox/3.6.8
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
Accept-Language: en-us,en;q=0.5
Accept-Encoding: gzip,deflate
Accept-Charset: ISO-8859-1,utf-8;q=0.7,*;q=0.7
Keep-Alive: 115
Connection: keep-alive
Origin: http://localhost
Access-Control-Request-Method: POST
Что происходит? Это ошибка в Firefox, или я делаю что-то не так? Спасибо!
Решение
Это действительно оказалось ошибкой Firefox. Это закончилось исправлено для FF4B6: https://bugzilla.mozilla.org/show_bug.cgi?id=588920.