AngularRouter路由守卫CanActivate始终返回false
创始人
2024-10-29 06:00:56
0

问题的原因是因为CanActivate守卫函数必须返回一个布尔对象,以允许或拒绝导航到相应的组件。如果该函数返回false,导航将被取消,并且将停留在当前页面。

下面是解决该问题的示例:

在路由定义中添加CanActivate守卫函数,在该函数中处理认证和授权逻辑,并根据结果返回true或false。

例如:

import { Injectable } from '@angular/core';
import { ActivatedRouteSnapshot, CanActivate, Router, RouterStateSnapshot } from '@angular/router';
import { AuthService } from './auth.service';

@Injectable()
export class AuthGuard implements CanActivate {
  constructor(private authService: AuthService, private router: Router) {}

  canActivate(route: ActivatedRouteSnapshot, state: RouterStateSnapshot): boolean {
    if (this.authService.isLoggedIn()) {
      return true;
    }

    // 认证失败,重定向到登录页面
    this.router.navigate(['/login']);
    return false;
  }
}

然后在路由定义中使用AuthGuard守卫函数,例如:

import { NgModule } from '@angular/core';
import { RouterModule, Routes } from '@angular/router';

import { HomeComponent } from './home/home.component';
import { LoginComponent } from './login/login.component';
import { AuthGuard } from './auth.guard';

const appRoutes: Routes = [
  { path: '', component: HomeComponent, canActivate: [AuthGuard] },
  { path: 'login', component: LoginComponent }
];

@NgModule({
  imports: [RouterModule.forRoot(appRoutes)],
  exports: [RouterModule]
})
export class AppRoutingModule {}

这就可以解决CanActivate始终返回false的问题,并在路由守卫函数中处理认证和授权逻辑。

相关内容

热门资讯

透视真的!如何下载德普之星辅助... 透视真的!如何下载德普之星辅助软件(透视)私人局辅助免费(果然有挂)1)如何下载德普之星辅助软件辅助...
透视游戏!aapoker安装包... 透视游戏!aapoker安装包怎么使用(透视)真的假的(确实是有挂);1、完成aapoker安装包怎...
透视脚本!德普之星辅助器(透视... 透视脚本!德普之星辅助器(透视)私人局辅助免费(一贯有挂)1、让任何用户在无需德普之星辅助器AI插件...
透视脚本!aapoker辅助工... 透视脚本!aapoker辅助工具安全吗(透视)插件下载(总是有挂)1、在aapoker辅助工具安全吗...
透视线上!德普之星透视辅助(透... 透视线上!德普之星透视辅助(透视)透视(竟然真的有挂)1、进入到德普之星透视辅助黑科技之后,能看到左...
透视智能ai!aapoker辅... 透视智能ai!aapoker辅助工具安全吗(透视)透视插件(总是存在有挂)1、不需要AI权限,帮助你...
透视教程!德普之星辅助器(透视... 透视教程!德普之星辅助器(透视)免费透视(原来是有挂);1、德普之星辅助器系统规律教程、德普之星辅助...
透视游戏!aapoker免费透... 透视游戏!aapoker免费透视脚本(透视)透视脚本(一直有挂);1、上手简单,内置详细流程视频教学...
透视规律!德普辅助软件(透视)... 透视规律!德普辅助软件(透视)私人局辅助免费(切实有挂)1、下载好德普辅助软件辅助软件之后点击打开,...
透视脚本!aapoker脚本(... 透视脚本!aapoker脚本(透视)发牌逻辑(原来存在有挂)透视脚本!aapoker脚本(透视)发牌...