Je voudrais ajouter un en-tête personnalisé à une demande AJAX POST de jQuery.
J'ai essayé ceci:
$.ajax({
type: 'POST',
url: url,
headers: {
"My-First-Header":"first value",
"My-Second-Header":"second value"
}
//OR
//beforeSend: function(xhr) {
// xhr.setRequestHeader("My-First-Header", "first value");
// xhr.setRequestHeader("My-Second-Header", "second value");
//}
}).done(function(data) {
alert(data);
});
Lorsque j'envoie cette demande et que je regarde avec FireBug, je vois cet en-tête:
OPTIONS xxxx / yyyy
Hôte HTTP / 1.1 : 127.0.0.1:6666
Agent utilisateur: Mozilla / 5.0 (Windows NT 6.1; WOW64; rv: 11.0) Gecko / 20100101 Firefox / 11.0
Accepter: text / html, application / xhtml + xml, application / xml; q = 0,9, / ; q = 0,8
Accept-Language: fr, fr-fr; q = 0,8, en-us; q = 0,5, en; q = 0,3
Accept-Encoding: gzip, deflate
Connection: keep -alive
Origin: null
Access-Control-Request-Method: POST
Access-Control-Request-Headers: my-first-header, my-second-header
Pragma: no-cache
Cache-Control: no-cache
Pourquoi mes en-têtes personnalisés vont-ils à Access-Control-Request-Headers
:
En-têtes de demande de contrôle d'accès: mon-premier-en-tête, mon-deuxième-en-tête
Je m'attendais à des valeurs d'en-tête comme celle-ci:
My-First-Header: première valeur
My-Second-Header: deuxième valeur
C'est possible?