【发布时间】:2018-11-30 10:25:25
【问题描述】:
这是一个初学者的角度问题。
我的 Angular 应用程序包含多个功能模块。我通过从 angular-cli 生成保护来使用 authguard,然后在我的应用程序路由模块中使用 CanActivate,如下所示:
import { NgModule } from '@angular/core';
import { Routes, RouterModule } from '@angular/router';
import { AuthGuard } from './auth.guard';
const routes: Routes = [
{path:'login',loadChildren:'./login/login.module#LoginModule',canActivate:
[AuthGuard]},
{path:'home', loadChildren:'./user/user.module#UserModule',canActivate:
[AuthGuard]},
{path:'cart',
loadChildren:'./cart/cart.module#CartModule',canActivate:[AuthGuard]},
{path:'customer',loadChildren:'./customer/customer.module#CustomerModule',canActivate:[AuthGuard]}
];
@NgModule({
imports: [RouterModule.forRoot(routes)],
exports: [RouterModule]
})
export class AppRoutingModule { }
在我的 auth guard 中,我写了防止用户访问未经授权的路由的条件:
import { Injectable } from '@angular/core';
import { CanActivate, ActivatedRouteSnapshot, RouterStateSnapshot } from
'@angular/router';
import { Observable } from 'rxjs/Observable';
import { Router } from '@angular/router';
@Injectable()
export class AuthGuard implements CanActivate {
constructor(private router: Router) { }
canActivate(
next: ActivatedRouteSnapshot,
state: RouterStateSnapshot): Observable<boolean> | Promise<boolean> | boolean
{
if(["user","customer","cart"].indexOf(localStorage.pass)>=0){alert("auth
guard!");
return true;}
else
this.router.navigate(['/login']);
}
}
构建后我收到警告 重建期间检测到 loadChildren 中的重复路径中的警告。我们将采用检测到的最新版本并覆盖它以节省重建时间。您应该执行完整构建以验证您的路线不重叠。
所以我用谷歌搜索它并找到this comment,在最后一条路径添加逗号后警告消失了。
但之后我登录到我的应用程序,控制台中出现以下消息: 限制历史状态更改以防止浏览器挂起 应用程序卡住了。
有什么想法吗?
编辑:我终于通过使用“canLoad”而不是“canActivate”让它工作了, 但如果有人能提供有关此问题的更多见解,那就太好了。
【问题讨论】:
-
如果我从路由模块中删除 canActivate auth 保护,应用程序工作正常。
-
在我的情况下,由于
canActive,它没有发生,但我处于无限循环中,从效果中调用相同的操作
标签: javascript angular browser