时间:2021-07-01 10:21:17 帮助过:31人阅读
我们这样创建一个interceptor。
接着注册interceptor.
以下是$http拦截的一些例子。
■ 拦截器中的异步操作
以上,是一个请求拦截,做了一个异步操作,根据异步操作的结果来更新config。
当然也有响应拦截。
■ Session拦截,请求拦截
服务端有2种类型的验证,一个是基于cookie的,一种是基于token的。对于基于token验证,当用户登录,获取一个来自服务端的token,这个token在每一次请求时发送给服务端。
创建一个有关session的injector:
可见,把从服务端返回的token放在了config.headers中。
注册injector:
发出一个请求:
拦截前大致是:
拦截后,在headers中多两个一个x-session-token字段:
■ 时间戳,请求和响应拦截
以上,在请求和响应时拦截,在config.requestTimestamp和config.responseTimestamp赋上当前的时间。
注册拦截器:
然后在运用的时候可以算出请求响应所耗去的时间。
■ 请求错误恢复,请求拦截
模拟一个请求拦截的错误情形:
拦截请求错误:
注册拦截器:
■ Session错误恢复,响应拦截
以上就是本文的全部内容,希望对大家的学习有所帮助。