我在我的应用程序中创建了一个拦截器来检测会话丢失(服务器发送 HTTP 419)。在这种情况下,我需要从服务器请求一个新会话,然后我想自动再次发送原始请求。
也许我可以将请求保存在请求拦截器中,然后再次发送,但可能有更简单的解决方案。
请注意,我必须使用特定的 Web 服务来创建会话。
angular.module('myapp', [ 'ngResource' ]).factory(
'MyInterceptor',
function ($q, $rootScope) {
return function (promise) {
return promise.then(function (response) {
// do something on success
return response;
}, function (response) {
if(response.status == 419){
// session lost
// create new session server-side
// Session.query();
// then send current request again
// ???
}
return $q.reject(response);
});
};
}).config(function ($httpProvider) {
$httpProvider.responseInterceptors.push('MyInterceptor');
});
这是我的解决方案,为感兴趣的人使用承诺。基本上,您需要请求一个新会话,并在发送与原始请求相对应的新请求之前等待响应(使用response.config)。通过返回承诺 $http(response.config),您可以确保响应将被视为原始请求。
(语法可能不是最好的,因为我是承诺的新手)
angular.module('myapp', [ 'ngResource' ]).factory(
'MyInterceptor',
function ($q, $rootScope) {
return function (promise) {
return promise.then(function (response) {
// do something on success
return response;
}, function (response) {
if(response.status == 419){
// session lost
var Session = $injector.get('Session');
var $http = $injector.get('$http');
// first create new session server-side
var defer = $q.defer();
var promiseSession = defer.promise;
Session.query({},function(){
defer.resolve();
}, function(){
// error
defer.reject();
});
// and chain request
var promiseUpdate = promiseSession.then(function(){
return $http(response.config);
});
return promiseUpdate;
}
return $q.reject(response);
});
};
}).config(function ($httpProvider) {
$httpProvider.responseInterceptors.push('MyInterceptor');
});
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)