Ajax添加Token到Header中的方法

登录后sessionStorage.setItem(“token”,token);

1.方法一:

$.ajax({
    type: "GET",
    url: "/access/getUser/" + userCode,
    headers: {'Authorization': token}
});

2.方法二:

$.ajax({
    type: "GET",
    url: "/access/getUser/" + userCode,
    beforeSend: function(request) {
        request.setRequestHeader("Authorization", token);
    },
    success: function(result) {
    }
});

Angularjs
方式1:

$http.post('/somePath' , someData , {
		headers : {'Authorization' : authToken}
	}).success(function(data, status, headers, config) {
	//...
	}).error(function(data, status, headers, config ) {
	//...
});

这种方法的好处就是针对不同路径的请求,可以个性化配置请求头部,缺点就是,不同路径请求都需要单独配置。
方式2:

ngular.module('app', [])
.config(function($httpProvider) {
    $httpProvider.defaults.headers.common = {'My-Header': 'value'}
})

$httpProvider.defaults.headers有不同的属性,如common、get、post、put等。因此可以在不同的http请求上面添加不同的头信息,common是指所有的请求方式。
这种方式添加请求头信息的优势就是可以给不同请求方式添加相同的请求头信息,缺点就是不能够为某些请求path添加个性化头信息。
方式3:

myModule.factory('authInterceptor', function($rootScope,  $cookies){
    return {
        request: function(config){
            config.headers = config.headers || {};
            if($cookies.get('token')){
                config.headers.authorization = 'Bearer ' + $cookies.get('token');
            }
            return config;
        },
        responseError: function(response){
            // ...
        }
    };
})

然后把上面定义的服务注册到$httpProvider.interceptors中。

.config(function($httpProvider){
    $httpProvider.interceptors.push('authInterceptor');
})
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值