詳解AngularJS中的http攔截
http攔截,即$http服務(wù)允許我們與服務(wù)端交互,有時候我們希望在發(fā)出請求之前以及收到響應(yīng)之后做些事情。
$httpProvider包含了一個interceptors的數(shù)組。
我們這樣創(chuàng)建一個interceptor。
app.factory('myInterceptor', ['$log', function($log){
$log.debug('');
var myInterceptor = {};
return myInterceptor;
}])
接著注冊interceptor.
app.config(['$httpProvider', function($httpProvider){
$httpProvider.interceptors.push('myInterceptor');
}])
以下是$http攔截的一些例子。
■ 攔截器中的異步操作
app.factory('myInterceotpr','someAsyncServcie', function($q, someAsyncServcie){
var requestInterceptor = {
request: function(config){
var deferred = %q.defer();
someAsyncService.doAsyncOperation().then(function(){
...
deferred.resolve(config);
}, function(){
...
deferred.resolve(config);
})
return deferred.promise;
}
};
return requestInterceptor;
})
以上,是一個請求攔截,做了一個異步操作,根據(jù)異步操作的結(jié)果來更新config。
當(dāng)然也有響應(yīng)攔截。
app.factory('myInterceptor',['$q', 'someAsyncService', function($q, someAsyncSercice){
var responseInterceptor = {
response: function(response){
var deferred = $q.defer();
someAsyncService.doAsyncOperation().then(function(response){
...
deferred.resolve(response);
}, function(response){
...
deferred.resolve(response);
})
return deferred.promise;
}
};
return responseInterceptor;
}])
■ Session攔截,請求攔截
服務(wù)端有2種類型的驗證,一個是基于cookie的,一種是基于token的。對于基于token驗證,當(dāng)用戶登錄,獲取一個來自服務(wù)端的token,這個token在每一次請求時發(fā)送給服務(wù)端。
創(chuàng)建一個有關(guān)session的injector:
app.factory('sessionInjector',['SessionService', function(SessionService){
var sessionInjector = {
request: function(config){
if(!SessionService.isAnonymous){
config.headers['x-session-token'] = SessionService.token;
}
return config;
}
};
return sessionInjector;
}])
可見,把從服務(wù)端返回的token放在了config.headers中。
注冊injector:
app.config(['$httpProvider', function($httpProvider){
$httpProvider.interceptors.push('sessionInjector');
}])
發(fā)出一個請求:
$http.get('');
攔截前大致是:
{
"transformRequest":[null],
"transformResponse":[null],
"method":"GET",
"url":"",
"headers":{
"Accept": "application/json, text/plain,*/*"
}
}
攔截后,在headers中多兩個一個x-session-token字段:
{
"transformRequest":[null],
"transformResponse":[null],
"method":"GET",
"url":"",
"headers":{
"Accept": "application/json, text/plain,*/*",
"x-session-token":......
}
}
■ 時間戳,請求和響應(yīng)攔截
app.factory('timestampMarker',[function(){
var timestampMarker = {
request:function(config){
config.requestTimestamp = new Date().getTime();
return config;
},
response: function(response){
response.config.responseTimestamp = new Date().getTime();
return config;
}
};
return timestampMarker;
}])
以上,在請求和響應(yīng)時攔截,在config.requestTimestamp和config.responseTimestamp賦上當(dāng)前的時間。
注冊攔截器:
app.config(['$httpProvider', function($httpProvider){
$httpProvider.interceptors.push('timestampMarker');
}])
然后在運用的時候可以算出請求響應(yīng)所耗去的時間。
$http.get('').then(function(response){
var time = response.config.responseTime - response.config.requestTimestamp;
console.log('請求耗去的時間為 ' + time);
})
■ 請求錯誤恢復(fù),請求攔截
模擬一個請求攔截的錯誤情形:
app.factory('requestRejector',['$q', function($q){
var requestRejector = {
request: function(config){
return $q.reject('requestRejector');
}
};
return requestRejector;
}])
攔截請求錯誤:
app.factory('requestRecoverer',['$q', function($q){
var requestRecoverer = {
requestError: function(rejectReason){
if(rejectReason === 'requestRejector'){
//恢復(fù)請求
return {
transformRequest:[],
transformResponse:[],
method:'GET',
url:'',
headers:{
Accept:'application/json, text/plain, */*'
}
};
} else {
return $q.reject(rejectReason);
}
}
};
return requestRecoverer;
}])
注冊攔截器:
app.config(['$httpProvider', function($httpProvider){
$httpProvider.interceptors.push('requestRejector');
$httpProvider.interceptors.push('requestRecoverer');
}])
■ Session錯誤恢復(fù),響應(yīng)攔截
app.factory('sessionRecoverer',['$q','$injector',function($q, $injector){
var sessionRecoverer = {
responseError: function(response){
//如果Session過期
if(response.status == 419){
var SessionService = $injector.get('SessionService');
var $http = $injector.get('$http');
var deferred = $q.defer();
//創(chuàng)建一個新的session
SessionService.login().then(deferred.resolve, deferred.reject);
return deferred.promise.then(function(){
reutrn $http(response.config);
})
}
return $q.reject(response);
}
};
return sessionRecoverer;
}])
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助。
- 簡介AngularJS中$http服務(wù)的用法
- 對比分析AngularJS中的$http.post與jQuery.post的區(qū)別
- 詳解AngularJS中$http緩存以及處理多個$http請求的方法
- AngularJS中$http服務(wù)常用的應(yīng)用及參數(shù)
- 后端接收不到AngularJs中$http.post發(fā)送的數(shù)據(jù)原因分析及解決辦法
- AngularJS通過$http和服務(wù)器通信詳解
- AngularJS出現(xiàn)$http異步后臺無法獲取請求參數(shù)問題的解決方法
- 淺談angularjs $http提交數(shù)據(jù)探索
- angularJS之$http:與服務(wù)器交互示例
- AngularJS中$http使用的簡單介紹
相關(guān)文章
AngularJS自定義過濾器用法經(jīng)典實例總結(jié)
這篇文章主要介紹了AngularJS自定義過濾器用法,結(jié)合實例形式總結(jié)分析了AngularJS自定義過濾器進行包含、替換、篩選、過濾、排序等操作相關(guān)實現(xiàn)技巧與注意事項,需要的朋友可以參考下2018-05-05
Angular 4依賴注入學(xué)習(xí)教程之Injectable裝飾器(六)
這篇文章主要給大家介紹了關(guān)于Angular 4依賴注入之Injectable裝飾器的相關(guān)資料,文中介紹的非常詳細(xì),對大家具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來跟著小編一起學(xué)習(xí)學(xué)習(xí)吧。2017-06-06
Angular.js回顧ng-app和ng-model使用技巧
這篇文章主要回顧Angular.js中ng-app和ng-model使用技巧,感興趣的小伙伴們可以參考一下2016-04-04
AngularJS 基礎(chǔ)ng-class-even指令用法
本文主要介紹AngularJS ng-class-even 指令,這里整理了ng-class-even基礎(chǔ)知識資料,并附實例代碼和效果圖,學(xué)習(xí)AngularJS指令的朋友可以看下2016-08-08

