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的值来决定是否通过路由守卫进行认证。

相关内容

热门资讯

黑科技智能ai(德州wepow... 黑科技智能ai(德州wepower)用模拟器(黑科技)黑科技设备(好像真的是有挂)1、金币登录送、破...
透视透明挂(WpK)黑科技下风... 透视透明挂(WpK)黑科技下风应对(黑科技)德州ai辅助神器(果然是真的有挂),您好,这款游戏可以开...
可靠辅助(微扑克)辅助器免费版... 可靠辅助(微扑克)辅助器免费版(辅助挂)辅助插件挂(其实是有挂)是一款可以让一直输的玩家,快速成为一...
黑科技真的(wepOke)ai... 黑科技真的(wepOke)ai代打技巧(黑科技)黑科技(其实有挂)(1)黑科技真的(wepOke)a...
透视插件(WPk)透明挂(黑科... 透视插件(WPk)透明挂(黑科技)德州ai机器人(切实是有挂)1)辅助挂:进一步探索辅助透视大陆,与...
科普辅助(微扑克)辅助工具(辅... 科普辅助(微扑克)辅助工具(辅助挂)有辅助挂吗(确实有挂)1、这是跨平台的黑科技,在线的操作超级的方...
透视模拟器(WPk)ai辅助(... 透视模拟器(WPk)ai辅助(黑科技)ai辅助(一直真的有挂)是一款可以让一直输的玩家,快速成为一个...
黑科技脚本(wEpoke)辅助... 黑科技脚本(wEpoke)辅助多久会封号(黑科技)辅助多久会封号(原来真的是有挂);小薇(透视辅助)...
黑科技了解(wepoker)a... 黑科技了解(wepoker)ai辅助(黑科技)显示有做弊(好像存在有挂)1)辅助挂:进一步探索辅助透...
详细辅助(微扑克)ai算牌器(... 详细辅助(微扑克)ai算牌器(辅助挂)ai胜率(一贯真的有挂)1、这是跨平台的黑科技,在线的操作超级...