jQuery JSONP ajax, заголовок аутентификации не установлен

Я пытаюсь сделать ajax-запрос к API контактов Google со следующей настройкой:

$.ajax({
  url: "https://www-opensocial.googleusercontent.com/api/people/@me/@all",
  dataType: 'jsonp',
  data: {
    alt: 'json-in-script'
  },
  headers: {
    'Authorization': 'Bearer ' + token
  },
  success: function(data, status) {
    return console.log("The returned data", data);
  }
});

Но заголовок Authentication, кажется, не установлен. Есть идеи?

Запрос

4 ответа

Решение

У меня недавно была такая же проблема. Попробуй это:

$.ajax({
  url: "https://www-opensocial.googleusercontent.com/api/people/@me/@all",
  dataType: 'jsonp',
  data: {
    alt: 'json-in-script'
  },
  success: function(data, status) {
    return console.log("The returned data", data);
  },
  beforeSend: function(xhr, settings) { xhr.setRequestHeader('Authorization','Bearer ' + token); } 
});

РЕДАКТИРОВАТЬ: Похоже, что это не может быть сделано с JSONP. Изменить заголовки HTTP для запроса JSONP

Когда требуется проверка подлинности в междоменном запросе, вы должны использовать какой-либо прокси-сервер.

С использованием dataType: jsonp приводит к тому, что HTTP-запрос фактически выполняется из сценария, который добавляется в DOM, заголовки устанавливаются в $.ajax не будет использоваться.

Похоже, что большинство ресурсов REST OAUTH2 принимают параметр access_token как часть URL запроса

http://self-issued.info/docs/draft-ietf-oauth-v2-bearer.html

пожалуйста, попробуйте следующий код:

$.ajax({
            dataType: 'jsonp',
            url: url,                
            data: {
                'access_token':token.access_token
            },
            jsonpCallback: 'thecallback',
            success: function(data){
                _cb(data);
            },
            error: function(d){
                _cb(d);
            }
        });

Просто сделайте это (jquery 2.0, но должен работать в предыдущих версиях)

    $.ajax({
        url: "/test",
        headers: {"Authorization": "Bearer " + $('#myToken').val()}
    })           
    .done(function (data) {
      console.log(data);
    })
    .fail(function (jqXHR, textStatus) {
      alert("error: " + textStatus);
    });
Другие вопросы по тегам