Angular路由守卫在订阅中未解析
创始人
2024-10-28 04:30:29
0

问题描述:当使用路由守卫来防止未授权的访问时,我们经常遇到在订阅内部无法解决的问题。这可能是由于订阅在路由守卫之前解析,因此路由守卫无法获取所需的数据。

解决方案:为了解决此问题,我们可以从rxjs中引入switchMap操作符,并使用它来返回可观察对象。这将确保我们的路由守卫能够解析所需的数据。

示例代码:

import { Injectable } from '@angular/core';
import { Router, CanActivate } from '@angular/router';
import { AuthService } from '../services/auth.service';
import { switchMap } from 'rxjs/operators';

@Injectable()
export class AuthGuard implements CanActivate {

  constructor(private authService: AuthService, private router: Router) {}

  canActivate() {
    return this.authService.isAuthenticated().pipe(
      switchMap((isAuthenticated) => {
        if (isAuthenticated) {
          return true;
        } else {
          this.router.navigateByUrl('/login');
          return false;
        }
      })
    );
  }

}

在上面的代码中,我们在canActivate函数中返回一个可观察对象,该对象使用 switchMap操作符将 isAuthenticated可观察对象映射为一个新的可观察对象。这样,我们的路由守卫就可以在完全解决订阅后使用 isAuthenticated的值来决定是否通过路由守卫进行认证。

相关内容

热门资讯

wpk有外 挂!wpk机器人代... wpk有外 挂!wpk机器人代打,WpK一直真的有挂,详细教程,(有挂揭秘)1、上手简单,内置详细流...
wepoke透视挂!aapok... wepoke透视挂!aapoker在哪里下载,wpk线上打法教学(详细辅助教程)关于wepoke透视...
wepoke辅助机器人!wep... wepoke辅助机器人!wepoke游戏真的是有挂的,wepOkE的确真的有挂,教你攻略(有挂插件)...
德州ai辅助软件!德州ai辅助... 德州ai辅助软件!德州ai辅助器,wpk德州原来是真的有挂(详细辅助挂教程)1、让任何用户在无需德州...
wpk外 挂!欢乐棋牌有外挂,... WePoker透视辅助工具核心要点解析‌,wpk外 挂!欢乐棋牌有外挂,线上德州有后台控制(详细透视...
微扑克ai辅助!wpk ai检... 微扑克ai辅助!wpk ai检测(Wpk)一直真的有挂-详细透明挂教程1、微扑克ai辅助优化,微扑克...
wepoke辅助技巧!wepo... wepoke辅助技巧!wepoke是有软件,wepoker好像真的有挂,实用技巧(有挂工具)1、这是...
德州ai辅助!德扑之星操作,德... 德州ai辅助!德扑之星操作,德州扑克一贯是有挂(详细ai辅助有用教程);致您一封信;亲爱德州ai辅助...
微扑克ai辅助!微扑克辅助,w... 微扑克ai辅助!微扑克辅助,wepoke科技(详细透视教程)1、不需要AI权限,帮助你快速的进行微扑...
德扑之星作弊!德州软件后台控制... 德扑之星作弊!德州软件后台控制,德州机器人都是存在有挂(详细作弊教程)1、金币登录送、破产送、升级送...