如果用户没有登录,想要一些安全的根,例如" / items" authguard返回false并且不导航" / login"。
export const APP_ROUTES: Routes = [
{path: '', component: PublicComponent, children: PUBLIC_ROUTES},
{
path: '',
component: SecureComponent,
resolve: {user: UserResolver},
canActivate: [AuthGuard],
children: SECURE_ROUTES
},
{path: '', redirectTo: '/login', pathMatch: 'full'}
];
AuthGuard代码:
@Injectable()
export class AuthGuard implements CanActivate {
constructor(private userService: UserService) {}
canActivate(route: ActivatedRouteSnapshot, state: RouterStateSnapshot){
let url: string = state.url;
return this.checkLogin(url);
}
checkLogin(url: string): Observable<boolean> {
this.userService.redirectUrl = url;
return this.userService.getPrincipal()
.map(user => {
if(user)
return true;
return false;
});
}
}
答案 0 :(得分:1)
注入Router
,如果用户未按如下方式登录,则重定向到登录页面:
@Injectable()
export class AuthGuard implements CanActivate {
constructor(private userService: UserService, private router: Router) {}
canActivate(route: ActivatedRouteSnapshot, state: RouterStateSnapshot): Observable<boolean> | Promise<boolean> | boolean{
let url: string = state.url;
return this.checkLogin(url);
}
checkLogin(url: string): Observable<boolean> {
this.userService.redirectUrl = url;
return this.userService.getPrincipal()
.map(user => {
if(user)
return true;
this.router.navigate(['login']);
return false;
});
}
}