欢迎您访问我爱IT技术网,今天小编为你分享的javascript教程:【详解AngularJS中的http拦截】,下面是详细的讲解!
详解AngularJS中的http拦截
http拦截,即$http服务允许我们与服务端交互,有时候我们希望在发出请求之前以及收到响应之后做些事情。
$httpProvider包含了一个interceptors的数组。
我们这样创建一个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;
})
以上,是一个请求拦截,做了一个异步操作,根据异步操作的结果来更新config。
当然也有响应拦截。
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拦截,请求拦截
服务端有2种类型的验证,一个是基于cookie的,一种是基于token的。对于基于token验证,当用户登录,获取一个来自服务端的token,这个token在每一次请求时发送给服务端。
创建一个有关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;
}])
可见,把从服务端返回的token放在了config.headers中。
注册injector:
app.config(['$httpProvider', function($httpProvider){
$httpProvider.interceptors.push('sessionInjector');
}])
发出一个请求:
$http.get('');
拦截前大致是:
{
"transformRequest":[null],
"transformResponse":[null],
"method":"GET",
"url":"",
"headers":{
"Accept": "application/json, text/plain,**",
"x-session-token":......
}
}
■ 时间戳,请求和响应拦截
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;
}])
以上,在请求和响应时拦截,在config.requestTimestamp和config.responseTimestamp赋上当前的时间。
注册拦截器:
app.config(['$httpProvider', function($httpProvider){
$httpProvider.interceptors.push('timestampMarker');
}])
然后在运用的时候可以算出请求响应所耗去的时间。
$http.get('').then(function(response){
var time=response.config.responseTime - response.config.requestTimestamp;
console.log('请求耗去的时间为 ' + time);
})
■ 请求错误恢复,请求拦截
模拟一个请求拦截的错误情形:
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'){
//恢复请求
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错误恢复,响应拦截
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();
//创建一个新的session
SessionService.login().then(deferred.resolve, deferred.reject);
return deferred.promise.then(function(){
reutrn $http(response.config);
})
}
return $q.reject(response);
}
};
return sessionRecoverer;
}])
以上就是本文的全部内容,希望对大家的学习有所帮助。
关于详解AngularJS中的http拦截的用户互动如下:
相关问题:如何测试AngularJS中的Service
答:Service的典型示例 在AngularJS中,Service都是单例的实体,通常会将Service作为向后台交互的数据提供者,所有的需要数据的组件只需要依赖于这个Service即可。 var app = angular.module('MyApp', []); app.factory('SearchSettingService', ['$... >>详细
相关问题:angularjs http怎么设置header
答:这个是比较纠结,尤其在spring下 get方法提交的参数要这样写:params要带上 $http.get(url, {params: 要传的参数obj }).success(function(data){ ...});post最好写成表单提交的形式 $http.({ method: 'POST', url: url, data: 要传的参数 >>详细
相关问题:为什么AngularJS的$http指定了Request Method无效
答:$http.post获得的返回不是个json么?取callback的success方法返回值就可以埃 $http({method : 'POST',url : 地址,data: 数据}).success(function(data, status, headers, config) {console.log(data);}).error(function(data, status, headers, .. >>详细
- 【firefox】firefox浏览器不支持innerText的解决
- 【Extjs】Extjs学习过程中新手容易碰到的低级错误
- 【clearInterval】js clearInterval()方法的定义
- 【ComboBox】ComboBox 和 DateField 在IE下消失的
- 【ajax】用js来解决ajax读取页面乱码-页面乱码
- 【addEventListener】addEventListener和attachEv
- 【dom】javascript dom追加内容实现示例-追加内容
- 【has】基于jquery的has()方法以及与find()方法以
- 【browser】jQuery下通过$.browser来判断浏览器.-
- 【extjs】Extjs入门之动态加载树代码-动态加载树
- 评论列表(网友评论仅供网友表达个人看法,并不表明本站同意其观点或证实其描述)
-
