Angular的AuthGuard在页面刷新时始终返回false,但我已经被认证。
创始人
2024-10-24 01:30:39
0

这可能是由于认证状态信息未能及时更新导致的。可以开启一个可观察数据流,订阅认证状态的更改,并将其保存到localStorage或sessionStorage中。在AuthGuard中,从关联的存储中读取状态信息,而不是直接从认证服务中获取。这样,在页面刷新后,状态信息将保持不变,AuthGuard将能够正确地返回true。

以下是一个可能的实现示例:

// authService.ts

import { Injectable } from '@angular/core'; import { BehaviorSubject } from 'rxjs';

@Injectable({ providedIn: 'root' }) export class AuthService { private isAuthenticated$ = new BehaviorSubject(false);

constructor() { }

login(username: string, password: string) { // authenticate user this.isAuthenticated$.next(true); }

logout() { // de-authenticate user this.isAuthenticated$.next(false); }

isAuthenticated(): Observable { return this.isAuthenticated$.asObservable(); } }

// authGuard.ts

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

@Injectable({ providedIn: 'root' }) export class AuthGuard implements CanActivate {

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

canActivate( next: ActivatedRouteSnapshot, state: RouterStateSnapshot): Observable {

return this.authService.isAuthenticated().pipe(
  map((isAuthenticated) => {
    if (isAuthenticated) {
      return true;
    } else {
      this.router.navigate(['/login']);
      return false;
    }
  })
);

} }

// app.module.ts

import { BrowserModule } from '@angular/platform-browser'; import { NgModule } from '@angular/core'; import { RouterModule, Routes } from '@angular/router';

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

const app

相关内容

热门资讯

9分钟实锤!德州ai辅助软件(... 9分钟实锤!德州ai辅助软件(德州ai)竟然是有挂(详细辅助曝光教程)1、任何德州ai辅助软件ai辅...
九分钟实锤!德扑之星有作弊(手... 九分钟实锤!德扑之星有作弊(手机德州)切实存在有挂(详细辅助安装教程);所有人都在同一条线上,像星星...
6分钟实锤!德州之星外挂(德州... 6分钟实锤!德州之星外挂(德州wepower)确实是真的有挂(详细辅助科技教程);1、下载好德州之星...
第五分钟实锤!德扑之星猫腻(德... 第五分钟实锤!德扑之星猫腻(德州nzt)切实真的有挂(详细辅助必胜教程);1、德扑之星猫腻系统规律教...
第十分钟实锤!德扑之星猫腻(来... 第十分钟实锤!德扑之星猫腻(来玩德州app)切实真的是有挂(详细辅助AI教程);1、下载好德扑之星猫...
第四分钟实锤!德州之星外挂(德... 第四分钟实锤!德州之星外挂(德州wpk)一贯存在有挂(详细辅助透明教程)1、操作简单,无需注册,只需...
第1分钟实锤!智星德州菠萝辅助... 第1分钟实锤!智星德州菠萝辅助器(智星德州)竟然真的有挂(详细辅助玩家教程)1、实时智星德州菠萝辅助...
第3分钟实锤!智星德州菠萝(德... 第3分钟实锤!智星德州菠萝(德州)原来真的是有挂(详细辅助线上教程);1、智星德州菠萝ai机器人多个...
4分钟实锤!德州之星有外挂(德... 4分钟实锤!德州之星有外挂(德州扑克)都是有挂(详细辅助德州教程);在进入德州之星有外挂辅助挂后,参...
三分钟实锤!智星德州菠萝开挂(... 三分钟实锤!智星德州菠萝开挂(德扑之星)确实是真的有挂(详细辅助力荐教程)1、操作简单,无需注册,只...