首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用刷新令牌时Angularjs拦截器循环依赖关系

使用刷新令牌时Angularjs拦截器循环依赖关系
EN

Stack Overflow用户
提问于 2015-08-10 17:03:14
回答 1查看 176关注 0票数 0

长话短说,我的angularjs应用程序中有一个基本如下的结构: 1.有一个“authService”,负责请求访问令牌和刷新令牌。2.有一个“authInterceptorService”将令牌添加到请求的头部,但是,这里有一个棘手的部分:该服务依赖于authService,以便在访问令牌过期且请求为401 on时使用刷新令牌生成新的访问令牌,这意味着当我使用$httpProvider服务注册拦截器时,最终会出现循环依赖:

authService <- authInterceptorService <- $http <- authService

我的问题是,当您的拦截器需要能够使用刷新令牌和REsend请求发出新的访问令牌时,如何才能绕过这个问题?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-08-10 18:13:45

绕过这一问题的一种方法是使用角的事件系统。由于您正在处理服务,您可能需要广播事件($emit)并在$rootScope上侦听它($on)。

例如,您可以为调用令牌刷新服务的“tokenExpired”事件设置一个侦听器,如果成功,该服务将触发一个“tokenRefreshed”事件。当请求为401 d时,您将发出tokenExpired事件,并为tokenRefreshed事件注册一个一次性侦听器,以便在刷新后重新发送请求。

也许不是最干净的解决方案,但我在处理严重的依赖链时使用了这样的设置,而且效果很好。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/31925238

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档