Как добавить пользовательский HTTP-заголовок в ajax-запрос с помощью js или jQuery?
Кто-нибудь знает, как добавить или создать собственный HTTP-заголовок с помощью JavaScript или jQuery?
Ответы
Ответ 1
Существует несколько решений в зависимости от того, что вам нужно...
Если вы хотите добавить собственный заголовок (или набор заголовков) к индивидуальному запросу, просто добавьте свойство headers
:
// Request with custom header
$.ajax({
url: 'foo/bar',
headers: { 'x-my-custom-header': 'some value' }
});
Если вы хотите добавить заголовок по умолчанию (или набор заголовков) к каждому запросу, используйте $.ajaxSetup()
:
$.ajaxSetup({
headers: { 'x-my-custom-header': 'some value' }
});
// Sends your custom header
$.ajax({ url: 'foo/bar' });
// Overwrites the default header with a new header
$.ajax({ url: 'foo/bar', headers: { 'x-some-other-header': 'some value' } });
Если вы хотите добавить заголовок (или набор заголовков) к каждому запросу, используйте beforeSend
hook с $.ajaxSetup()
:
$.ajaxSetup({
beforeSend: function(xhr) {
xhr.setRequestHeader('x-my-custom-header', 'some value');
}
});
// Sends your custom header
$.ajax({ url: 'foo/bar' });
// Sends both custom headers
$.ajax({ url: 'foo/bar', headers: { 'x-some-other-header': 'some value' } });
Изменить (подробнее):. Одна вещь, о которой нужно знать, это то, что при ajaxSetup
вы можете определить только один набор заголовков по умолчанию, и вы можете определить только один beforeSend
. Если вы вызовете ajaxSetup
несколько раз, будет отправлен только последний набор заголовков, и будет выполнен только последний обратный вызов до отправки.
Ответ 2
Или, если вы хотите отправить пользовательский заголовок для каждого будущего запроса, вы можете использовать следующее:
$.ajaxSetup({
headers: { "CustomHeader": "myValue" }
});
Таким образом, каждый будущий аякс-запрос будет содержать пользовательский заголовок, если явно не переопределить параметры запроса. Вы можете найти более подробную информацию о ajaxSetup
здесь
Ответ 3
Вот пример использования XHR2:
function xhrToSend(){
// Attempt to creat the XHR2 object
var xhr;
try{
xhr = new XMLHttpRequest();
}catch (e){
try{
xhr = new XDomainRequest();
} catch (e){
try{
xhr = new ActiveXObject('Msxml2.XMLHTTP');
}catch (e){
try{
xhr = new ActiveXObject('Microsoft.XMLHTTP');
}catch (e){
statusField('\nYour browser is not' +
' compatible with XHR2');
}
}
}
}
xhr.open('POST', 'startStopResume.aspx', true);
xhr.setRequestHeader("chunk", numberOfBLObsSent + 1);
xhr.onreadystatechange = function (e) {
if (xhr.readyState == 4 && xhr.status == 200) {
receivedChunks++;
}
};
xhr.send(chunk);
numberOfBLObsSent++;
};
Надеюсь, что это поможет.
Если вы создаете свой объект, вы можете использовать функцию setRequestHeader для назначения имени и значения перед отправкой запроса.
Ответ 4
Предполагая, что JQuery ajax, вы можете добавить собственные заголовки, например -
$.ajax({
url: url,
beforeSend: function(xhr) {
xhr.setRequestHeader("custom_header", "value");
},
success: function(data) {
}
});
Ответ 5
Вы также можете сделать это, не используя jQuery. Переопределите метод отправки XMLHttpRequest и добавьте туда заголовок:
XMLHttpRequest.prototype.realSend = XMLHttpRequest.prototype.send;
var newSend = function(vData) {
this.setRequestHeader('x-my-custom-header', 'some value');
this.realSend(vData);
};
XMLHttpRequest.prototype.send = newSend;
Ответ 6
Вам следует избегать использования $.ajaxSetup()
, как описано в docs. Вместо этого используйте следующее:
$(document).ajaxSend(function(event, jqXHR, ajaxOptions) {
jqXHR.setRequestHeader('my-custom-header', 'my-value');
});
Ответ 7
Предполагая, что вы имеете в виду "При использовании ajax" и "Заголовок HTTP-запроса", используйте свойство headers
в объекте, который вы передаете на ajax()
(добавлено 1.5)
По умолчанию: {}
Карта дополнительных пар ключ/значение заголовка для отправки вместе с запросом. Этот параметр устанавливается до вызова функции beforeSend; поэтому любые значения в настройках заголовков могут быть перезаписаны из функции beforeSend.
- http://api.jquery.com/jQuery.ajax/
Ответ 8
"setRequestHeader" следует использовать метод объекта XMLHttpRequest
http://help.dottoro.com/ljhcrlbv.php
Ответ 9
Вы можете использовать js fetch
async function send(url,data) {
let r= await fetch(url, {
method: "POST",
headers: {
"My-header": "abc"
},
body: JSON.stringify(data),
})
return await r.json()
}
// Example usage
let url='https://server.test-cors.org/server?enable=true&status=200&methods=POST&headers=my-header';
async function run()
{
let jsonObj = await send(url,{ some: 'testdata' });
console.log(jsonObj[0].request.httpMethod + ' was send - open chrome console > network to see it');
}
run();