大佬教程收集整理的这篇文章主要介绍了angularjs – $location.path无法从http拦截器工作,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
function($LOCATIOn,$q) { return { request: function (config) { return config || $q.when(config); },requestError: function(request){ return $q.reject(request); },response: function (responsE) { return response || $q.when(responsE); },responseError: function (responsE) { if (response && response.status === 401) { $LOCATIOn.path('/login'); } return $q.reject(responsE); } }; }
问题是$LOCATIOn.path(‘/ login’)调用似乎不起作用,路径被完全忽略,我仍然在我的会话到期时我所在的路径(尽管是一个空白页面).一种可能的解决方法是使用传统的window.LOCATIOn =’/#!/ login’;但我觉得这不太理想.我还发现如果我删除返回$q.reject(响应);我得到它的工作,但这引入了另一个错误,其中无法找到响应的数据属性(此处讨论的解决方案:Angular.js $http.post TypeError: Cannot read property ‘data’ of undefined).
我正在跑角1.2.21.
关于可能会发生什么的任何想法?回到window.LOCATIOn不是世界的尽头,但我喜欢这个神秘的一个很好的整洁解决方案:).
提前致谢.
我不确定,但看起来$LOCATIOn.path(…)不会改变位置,因为应用程序等待直到所有的promises将被解析,并且拦截器内的promise被拒绝(返回$q.reject(responsE);)
在我的情况下,执行http请求的服务放在UI路由器状态的resolve部分内,因此我可以使用$stateChangeError事件来处理错误.
(对于ngRoute使用$routeChangeError事件)
希望这可以帮到你 :)
PS必须有一些更好的解决方案
更新:
更普遍的解决方法:
@H_800_5@module.config中的拦截器
... responseError: function (responsE) { if (response && response.status === 401) { $rootScope.$emit('loginrequired'); } return $q.reject(responsE); } ...
和事件处理程序在module.run部分的某处
$rootScope.$on('loginrequired',function() { $LOCATIOn.path('/login'); });
(我用$state.go(‘login’)测试了处理程序,但$LOCATIOn.path(‘/ login’);也应该工作:))
以上是大佬教程为你收集整理的angularjs – $location.path无法从http拦截器工作全部内容,希望文章能够帮你解决angularjs – $location.path无法从http拦截器工作所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。