9

登录到远程 API 服务器并获得 access_token 后,我尝试为所有后续 ajax 调用设置授权标头:

      .done(function (result) {
         console.log("GOT AUTHORIZATION");
         amplify.store( "tokens", { access_token: result.access_token, refresh_token: result.refresh_token, token_type: result.token_type, expires_in: result.expires_in });
         var authorization = 'Bearer ' + amplify.store( "tokens" ).access_token;
         console.log(authorization);

         $.ajaxSetup({
             beforeSend: function(xhr) {
                 xhr.setRequestHeader('Authorization', authorization);
             }
         });

在控制台上我可以看到:

GOT AUTHORIZATION login.js:34
Bearer 6b7578772fbb4178793100651f2234de840237fe

但是后续的 ajax 调用都没有得到正确的标头集:

https://macmini.local:8000/Categories?_=1381758170726 

无法成功,因为在标头(服务器控制台..)中找不到 access_token

{ code: 400,
   error: 'invalid_request',
   error_description: 'The access token was not found',stack: undefined }
saveAccessToken: 6b7578772fbb4178793100651f2234de840237fe, client_id: 1234567890, user_id: 1

我试图修改 ajax 调用中的标题 wo 任何成功

4

2 回答 2

17

更新的答案

从 jQuery 1.5 开始.ajax支持headers属性

$.ajax({
    url: "http://fiddle.jshell.net/favicon.png",
    headers: {
        'Authorization': authorization
    }
})
.done(function( data ) {
    if ( console && console.log ) {
        console.log( "Sample of data:", data.slice( 0, 100 ) );
    }
});

注意:该authorization变量应在此调用之前设置


旧答案

$(function(){
    $.ajaxSetup({
        beforeSend: function(xhr) {
                 xhr.setRequestHeader('Authorization', authorization);
             }
    });
});

为了ajaxSetup工作,您需要在 document.ready 中调用它。

于 2013-10-14T14:14:11.650 回答
0

我知道这是一个老问题,但我从谷歌来到这里,并认为其他搜索相同内容的人应该有一个可行的解决方案。我已经尝试了建议的答案,但它对我不起作用。

解决我的问题的解决方案是直接在xhr对象内部设置标题$.ajaxSend

$(document).ajaxSend(function(ev, xhr, settings) {
  xhr.setRequestHeader('Authorization', `Bearer ${localStorage.getItem(AUTH_TOKEN)}`);
  xhr.setRequestHeader('X-Marketplace', localStorage.getItem('marketplace'));
});

你应该调用它document.readyajaxSend工作。

那个类似的问题帮助了我。

于 2018-12-06T20:03:58.187 回答