详解AngularJS中的http拦截

前端之家收集整理的这篇文章主要介绍了详解AngularJS中的http拦截前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

http拦截

,即$http服务允许我们与服务端交互,有时候我们希望在发出请求之前以及收到响应之后做些事情。 $httpProvider包含了一个interceptors的数组。

我们这样创建一个interceptor。

var myInterceptor = {};

return myInterceptor;
}])

接着注册interceptor.

以下是$http拦截的一些例子。

拦截器中的异步操作

return requestInterceptor;
})

以上,是一个请求拦截,做了一个异步操作,根据异步操作的结果来更新config。

当然也有响应拦截

■ Session拦截,请求拦截

服务端有2种类型的验证,一个是基于cookie的,一种是基于token的。对于基于token验证,当用户登录获取一个来自服务端的token,这个token在每一次请求时发送给服务端。

创建一个有关session的injector:

return sessionInjector;
}])

可见,把从服务端返回的token放在了config.headers中。

注册injector:

发出一个请求:

拦截前大致是:

拦截后,在headers中多两个一个x-session-token字段:

■ 时间戳,请求和响应拦截

return timestampMarker;
}])

以上,在请求和响应时拦截,在config.requestTimestamp和config.responseTimestamp赋上当前的时间。

注册拦截器:

然后在运用的时候可以算出请求响应所耗去的时间。

■ 请求错误恢复,请求拦截

模拟一个请求拦截错误情形:

拦截请求错误

return requestRecoverer;
}])

注册拦截器:

■ Session错误恢复,响应拦截

//创建一个新的session SessionService.login().then(deferred.resolve,deferred.reject); return deferred.promise.then(function(){ reutrn $http(response.config); })

}
return $q.reject(response);
}
};

return sessionRecoverer;
}])

以上就是本文的全部内容,希望对大家的学习有所帮助。

原文链接:https://www.f2er.com/js/50183.html

猜你在找的JavaScript相关文章