在Angular 6中,可以使用路由守卫来重定向到登录页面进行身份验证。下面是一个示例代码,演示了如何使用身份验证守卫来实现此目的。
首先,创建一个名为AuthGuard的身份验证守卫服务,该服务将用于检查用户是否已经登录。在该服务中,我们使用CanActivate接口来实现路由守卫。
import { Injectable } from '@angular/core';
import { CanActivate, Router } from '@angular/router';
@Injectable()
export class AuthGuard implements CanActivate {
constructor(private router: Router) {}
canActivate(): boolean {
if (localStorage.getItem('currentUser')) {
// 用户已经登录,返回true,允许访问
return true;
}
// 用户未登录,重定向到登录页面
this.router.navigate(['/login']);
return false;
}
}
接下来,在你的路由配置中使用AuthGuard来保护需要身份验证的页面。在下面的示例中,我们将AuthGuard应用于dashboard路由,以确保只有登录用户可以访问该页面。
import { NgModule } from '@angular/core';
import { Routes, RouterModule } from '@angular/router';
import { AuthGuard } from './auth.guard';
import { LoginComponent } from './login.component';
import { DashboardComponent } from './dashboard.component';
const routes: Routes = [
{ path: 'login', component: LoginComponent },
{ path: 'dashboard', component: DashboardComponent, canActivate: [AuthGuard] },
// 其他路由配置...
];
@NgModule({
imports: [RouterModule.forRoot(routes)],
exports: [RouterModule]
})
export class AppRoutingModule { }
在上面的代码中,我们通过将canActivate属性设置为[AuthGuard]来应用AuthGuard守卫。
最后,在登录成功时,我们可以将用户信息保存在本地存储中。以下是一个简单的示例:
import { Component } from '@angular/core';
import { Router } from '@angular/router';
@Component({
selector: 'app-login',
template: `
`
})
export class LoginComponent {
constructor(private router: Router) {}
login() {
// 在此处进行实际的登录逻辑
// ...
// 登录成功后,将用户信息保存在本地存储中
localStorage.setItem('currentUser', JSON.stringify({ username: 'user1' }));
// 导航到受保护的页面
this.router.navigate(['/dashboard']);
}
}
在上面的代码中,我们在登录按钮的点击事件中调用了登录方法。在登录成功后,我们保存了用户信息,并使用this.router.navigate(['/dashboard'])来导航到受保护的dashboard页面。
这就是使用身份验证守卫来重定向到登录页面的解决方法。希望对你有所帮助!