ログインしていないユーザーが「/ items」などのセキュアルートに移動したい場合、authguardはfalseを返し、「login」をナビゲートしません。Angular2 Authguardのログインへの経路
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;
});
}
}
質問はここで何です:)? –
ユーザーがログインしていない場合、ログインページをナビゲートしたいのですか? :) – vangoo
@vangoo下のコードを試しましたか? –