在Angular 6中,可以通过路由守卫(route guards)实现允许用户在未登录的情况下访问页面。下面是一个示例代码:
auth.guard.ts的路由守卫文件:import { Injectable } from '@angular/core';
import { CanActivate, ActivatedRouteSnapshot, RouterStateSnapshot, Router } from '@angular/router';
@Injectable({
providedIn: 'root'
})
export class AuthGuard implements CanActivate {
constructor(private router: Router) { }
canActivate(next: ActivatedRouteSnapshot, state: RouterStateSnapshot): boolean {
// 在此处添加你的身份验证逻辑,判断用户是否已登录
const isLoggedIn = true; // 假设用户已登录
if (isLoggedIn) {
return true; // 允许访问目标页面
} else {
this.router.navigate(['/login']); // 未登录时重定向到登录页面
return false; // 阻止访问目标页面
}
}
}
app.module.ts中将AuthGuard添加到providers数组中:import { NgModule } from '@angular/core';
import { RouterModule, Routes } from '@angular/router';
import { AuthGuard } from './auth.guard';
const routes: Routes = [
{ path: 'home', component: HomeComponent, canActivate: [AuthGuard] },
// 添加其他路由配置
];
@NgModule({
imports: [RouterModule.forRoot(routes)],
exports: [RouterModule],
providers: [AuthGuard] // 添加AuthGuard到providers数组中
})
export class AppModule { }
在上面的示例中,AuthGuard实现了CanActivate接口,并重写了canActivate方法。在canActivate方法中,我们可以编写自己的身份验证逻辑。如果用户已登录,返回true允许访问目标页面;如果用户未登录,通过路由导航到登录页面并返回false阻止访问目标页面。
在routes数组中,我们使用canActivate属性将AuthGuard应用到需要进行身份验证的路由上。这样,在用户访问这些路由时,Angular会自动调用canActivate方法进行身份验证。
请注意,上述代码中的身份验证逻辑是一个简化示例,你需要根据你的实际需求进行修改。