Как я могу передать заголовки запроса с помощью метода getJSON () jQuery? - PullRequest
69 голосов
/ 12 июля 2010

Мне нужно сделать запрос getJSON(), но как мне пройти авторизацию и пользовательские заголовки?

У меня возникают проблемы с тем, что заголовок запроса принимает имя, но НЕ значения.URL отображается в ручном запросе в fiddler на вставку в качестве параметров вместо GET / Url.

Вот пример того, что мы пытаемся сделать, и это прекрасно работает в fiddler;как я могу повторить это с помощью функции AJAX?

GET /Service.svc/logins/gdd53535342/houses/vxcbdfsdg/people/dsgsdggd?format=json HTTP/1.1
User-Agent: Fiddler
Authorization: Basic rgbg423535fa23y4436
X-PartnerKey: df3fgeg-g5g6-b55b-f3d2-dsgg353523
Host: 154.34.53.54:2757

Код JavaScript:

xhr = new XMLHttpRequest();

$(document).ready(function() {
  $.ajax({
    url: 'http://localhost:437/service.svc/logins/jeffrey/house/fas6347/devices?format=json',
    type: 'GET',
    datatype: 'json',
    success: function() { alert("Success"); },
    error: function() { alert('Failed!'); },
    beforeSend: setHeader       
  });   
});

function setHeader(xhr) {
  xhr.setRequestHeader('Authorization', 'Basic faskd52352rwfsdfs');
  xhr.setRequestHeader('X-PartnerKey', '3252352-sdgds-sdgd-dsgs-sgs332fs3f');
}

Заголовки обычного запроса Fiddler:

GET /service.svc/logins/jeffrey/house/fas6347/devices?format=json HTTP/1.1
User-Agent: Fiddler
Authorization: Basic faskd52352rwfsdfs
X-PartnerKey: 3252352-sdgds-sdgd-dsgs-sgs332fs3f
Host: localhost:437

Через Fiddler * Ajax()Заголовки запроса:

OPTIONS service.svc/logins/jeffrey/house/fas6347/devices?format=json HTTP/1.1
Host: localhost:437
User-Agent: Mozilla/5.0 (Windows; U; Windows NT 6.1; en-US; rv:1.9.2.6) Gecko/20100625 Firefox/3.6.6
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
Proxy-Connection: keep-alive
Origin: http://ipv4.fiddler:61975
Access-Control-Request-Method: GET
Access-Control-Request-Headers: authorization,x-partnerkey

Ответы [ 3 ]

78 голосов
/ 12 июля 2010

Я согласен с sunetos, что вам придется использовать функцию $ .ajax для передачи заголовков запросов.Для этого вам нужно написать функцию для обработчика события beforeSend, которая является одной из опций $ .ajax ().Вот краткий пример того, как это сделать:

<html>
  <head>
    <script src="http://code.jquery.com/jquery-1.4.2.min.js"></script>
    <script type="text/javascript">
      $(document).ready(function() {
        $.ajax({
          url: 'service.svc/Request',
          type: 'GET',
          dataType: 'json',
          success: function() { alert('hello!'); },
          error: function() { alert('boo!'); },
          beforeSend: setHeader
        });
      });

      function setHeader(xhr) {
        xhr.setRequestHeader('securityCode', 'Foo');
        xhr.setRequestHeader('passkey', 'Bar');
      }
    </script>
  </head>
  <body>
    <h1>Some Text</h1>
  </body>
</html>

Если вы запустите приведенный выше код и посмотрите трафик в таком инструменте, как Fiddler, вы увидите два заголовка запросов, переданных:

  • securityCode со значением Foo
  • пароль со значением Bar

Функция setHeader также может быть встроенной в параметрах $ .ajax, но я хотел вызватьэто.

Надеюсь, это поможет!

32 голосов
/ 15 февраля 2014

Я думаю, что вы можете установить заголовки и по-прежнему использовать getJSON () следующим образом:

$.ajaxSetup({
  headers : {
    'Authorization' : 'Basic faskd52352rwfsdfs',
    'X-PartnerKey' : '3252352-sdgds-sdgd-dsgs-sgs332fs3f'
  }
});
$.getJSON('http://localhost:437/service.svc/logins/jeffrey/house/fas6347/devices?format=json', function(json) { alert("Success"); }); 
15 голосов
/ 12 июля 2010

Метод $.getJSON() - это сокращение, которое не позволяет указывать дополнительные параметры, подобные этому. Для этого вам нужно использовать полный метод $.ajax().

Примечание в документации на http://api.jquery.com/jQuery.getJSON/:

Это сокращенная Ajax-функция, которая эквивалентна:

$.ajax({
  url: url,
  dataType: 'json',
  data: data,
  success: callback
});

Так что просто используйте $.ajax() и предоставьте все дополнительные параметры, которые вам нужны.

...