Angular的canActivate路由守卫出现无限循环问题
创始人
2024-10-24 02:00:31
0

通过使用 BehaviorSubject 来保存和共享认证状态,并且在认证状态变化时发出通知。

代码示例:

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

@Injectable()
export class AuthGuard implements CanActivate {
  private isAuthenticatedSubject = new BehaviorSubject(false);

  constructor(private authService: AuthService, private router: Router) {
    this.authService.isAuthenticated().subscribe(isAuthenticated => {
      this.isAuthenticatedSubject.next(isAuthenticated);
    });
  }

  canActivate(next: ActivatedRouteSnapshot, state: RouterStateSnapshot): Observable | Promise | boolean {
    return this.isAuthenticatedSubject.take(1).map(isAuthenticated => {
      if (!isAuthenticated) {
        this.router.navigate(['/login']);
        return false;
      }
      return true;
    });
  }
}

在这个例子中,我们通过 BehaviorSubject 类创建了一个 isAuthenticatedSubject 对象,并设置其初始值为 false。这个对象用来保存认证状态,并且可以在多个地方订阅和获取其值。在 AuthGuard 构造函数中,我们订阅了 AuthGuard 服务的 isAuthenticated 方法,当这个方法的返回值发生变化时,会发出一个新的认证状态,我们则将其保存到 isAuthenticatedSubject 中。在 canActivate 方法中,我们通过 isAuthenticatedSubject.take(1) 实现了只获取一次 isAuthenticatedSubject 的值,并将其映射为一个布尔值。如果当前用户未认证,则会被重定向到登录页,并返回 false,否则返回 true。

相关内容

热门资讯

透视辅助!hhpoker有没有... 透视辅助!hhpoker有没有透视辅助(透视)werplan脚本,教程策略(竟然有挂)-哔哩哔哩1、...
透视教你!wepoker模拟器... 您好,wepoker到底有没有透视这款游戏可以开挂的,确实是有挂的,需要了解加去威信【4852750...
透视透视!wepoker怎么开... 透视透视!wepoker怎么开辅助(透视)佛手大菠萝13道挂哪里,教程攻略(真是有挂)-哔哩哔哩1、...
透视透视!hhpoker真的有... 透视透视!hhpoker真的有透视吗(透视)pokermaster破解版,教程策略(确实有挂)-哔哩...
透视揭露!wepoker能不能... 透视揭露!wepoker能不能透视(透视)wepoker免费透视脚本,教程窍要(有挂详细)-哔哩哔哩...
透视解迷!wpk刷入池率脚本(... 透视解迷!wpk刷入池率脚本(透视)wepoker高级辅助,教程技法(真的有挂)-哔哩哔哩1、玩家可...
透视推荐!wepoker亲友圈... 透视推荐!wepoker亲友圈有用吗(透视)wepoker透视有没有,教程教材(有挂详细)-哔哩哔哩...
透视分享!hhpoker智能辅... 透视分享!hhpoker智能辅助插件(透视)有没有人wepoker,教程教程书(真实有挂)-哔哩哔哩...
透视推荐!pokermaste... 透视推荐!pokermaster脚本(透视)佛手在线大菠萝技巧,教程手段(有挂规律)-哔哩哔哩1、很...
透视分享!哈糖大菠萝开挂(透视... 透视分享!哈糖大菠萝开挂(透视)wpk私人局辅助是真的吗,教程练习(有挂技术)-哔哩哔哩1、这是跨平...