角度 js 返回用户自动登录

angular js returning user autologin

本文关键字:登录 用户 js 返回 角度      更新时间:2023-09-26

我有一个通过令牌的身份验证系统。用户使用电子邮件和密码登录,令牌将返回并保存在 cookie 中。现在,如果用户关闭浏览器或选项卡并返回站点,则用户将使用cookie中的令牌进行身份验证,但是,这可能需要相当多的毫秒,并且如果他们返回到安全站点(例如其用户配置文件),并且应用程序不够快,无法加载初始用户数据并将其标记为已登录, 然后他们被重定向到登录页面。

我的第一个想法只是将用户数据放在每个请求的响应中,其中令牌是有效的,但这会产生大量不必要的数据流量。

有没有更好的解决方案?

在路由上使用解析以等待加载用户信息。因此,是重定向到登录页面还是允许路由访问取决于加载用户处理程序的处理程序。例如:

function requiresLogin(){
return ["$auth",function($auth){
return $auth.verifiedUser();
}];
}
$routeProvider.when("...",{
....,
resolve:{
user:requiresLogin()
}
});

在您的$auth服务中:

angular.module("app").factory("$auth", ["$q", "$http", function($q,$http){
var loaded, loggedIn = false;
//load user 
loaded = $http.get(....).then(function(result){
loggedIn = result.loggedIn;
});
return {
verifiedUser:function(){
return loaded.then(function(){
    if(loggedIn)
return true;
else
return $q.reject();
});
}
};
}]);

未经测试的代码,只是为了给出一个关于如何做到这一点的想法。

如果没有更多的代码,我们无法提供明确的答案。