【发布时间】:2020-03-23 13:57:13
【问题描述】:
我想知道是否可以在 Angular 应用程序中保护方法而不是路由。假设您有一个按钮,如果您单击它但未登录,您将被重定向到登录页面。
谢谢
【问题讨论】:
标签: angular angular-router-guards
我想知道是否可以在 Angular 应用程序中保护方法而不是路由。假设您有一个按钮,如果您单击它但未登录,您将被重定向到登录页面。
谢谢
【问题讨论】:
标签: angular angular-router-guards
方法没有这样的守卫。相反,最可能的解决方案是在您想要保护的方法中创建条件检查。
例如,如果需要保护的方法是 checkoutCart() 并且您的 Angular 应用程序中有一个服务会通知您用户是否登录。那么这就是您可以在 checkoutCart() 方法中执行的操作:
checkoutCart() {
if ( !this._authenticationService.isLoggedIn ) {
this.router.navigate(['/', 'login']).then(nav => {
console.log(nav); // true if navigation is successful
}, err => {
console.log(err) // when there's an error
});
return;
}
// REST OF YOUR PROTECTED CODE
}
要了解路由器的工作原理,您可以参考:https://alligator.io/angular/navigation-routerlink-navigate-navigatebyurl/
【讨论】:
这是一个工作示例。主要逻辑在 auth 守卫中,如果它没有登录,我们会重定向到登录页面。
canActivate(next: ActivatedRouteSnapshot,
state: RouterStateSnapshot): Observable<boolean> {
let url: string = state.url;
return this.loggedInService.isLoggedIn$.pipe(map(data => {
if(!data) {
this.router.navigate(['login']);
}
return data;
}));
}
【讨论】: