Как я могу добавить пользовательский заголовок HTTP к запросу ajax с помощью js или jQuery? - PullRequest
307 голосов
/ 07 октября 2011

Кто-нибудь знает, как добавить или создать собственный заголовок HTTP с помощью JavaScript или jQuery?

Ответы [ 9 ]

556 голосов
/ 02 февраля 2013

Существует несколько решений в зависимости от того, что вам нужно ...

Если вы хотите добавить пользовательский заголовок (или набор заголовков) к отдельному запросу , тогда просто добавьте 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 ловушку с $.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' } });

Редактировать (большеinfo): Следует помнить, что с ajaxSetup вы можете определить только один набор заголовков по умолчанию и один beforeSend.Если вы наберете ajaxSetup несколько раз, будет отправлен только последний набор заголовков и будет выполнен только последний обратный вызов перед отправкой.

52 голосов
/ 16 июля 2012

Или, если вы хотите отправить настраиваемый заголовок для каждого будущего запроса, вы можете использовать следующее:

$.ajaxSetup({
    headers: { "CustomHeader": "myValue" }
});

Таким образом, каждый будущий запрос ajax будет содержать настраиваемый заголовок, если явно не переопределеноварианты запроса.Вы можете найти больше информации о ajaxSetup здесь

18 голосов
/ 07 октября 2011

Вот пример использования 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, чтобы назначить имя и значение перед вами.отправьте запрос.

17 голосов
/ 25 мая 2016

Вы также можете сделать это без использования 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;
17 голосов
/ 07 октября 2011

Предполагая JQuery ajax, вы можете добавить пользовательские заголовки, такие как -

$.ajax({
  url: url,
  beforeSend: function(xhr) {
    xhr.setRequestHeader("custom_header", "value");
  },
  success: function(data) {
  }
});
12 голосов
/ 12 июля 2015

Вам следует избегать использования $.ajaxSetup(), как описано в документах .Вместо этого используйте следующее:

$(document).ajaxSend(function(event, jqXHR, ajaxOptions) {
    jqXHR.setRequestHeader('my-custom-header', 'my-value');
});
6 голосов
/ 07 октября 2011

Предполагая, что вы имеете в виду «При использовании ajax» и «HTTP Request header», используйте свойство headers в объекте, который вы передаете ajax()

заголовки (добавлено 1,5)

По умолчанию: {}

Карта дополнительных пар ключ / значение заголовка для отправки вместе с запросом. Этот параметр устанавливается до вызова функции beforeSend; поэтому любые значения в настройке заголовков могут быть перезаписаны из функции beforeSend.

- http://api.jquery.com/jQuery.ajax/

3 голосов
/ 07 октября 2011

Следует использовать метод "setRequestHeader" объекта XMLHttpRequest

http://help.dottoro.com/ljhcrlbv.php

0 голосов
/ 09 апреля 2019

Вы можете использовать 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();
...