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

相关内容

热门资讯

推荐一款!!德扑是真的有挂一贯... 推荐一款!!德扑是真的有挂一贯,德扑ai操作好像真的有挂(详细ai软件教程);一、AI软件牌型概率发...
透视辅助!wpK透视辅助技巧,... 透视辅助!wpK透视辅助技巧,德州wpk其实是真的有挂(详细有外卦挂教程)1、玩家可以在软件透明挂俱...
透视辅助!德州aapoker切... 透视辅助!德州aapoker切实是有挂,aapoker工具一直是有挂(详细有挂教程)辅助器中分为三种...
透视辅助!德州aapoker俱... 透视辅助!德州aapoker俱乐部正确打法,aapoker规律竟然是真的有挂(详细透视辅助教程)1、...
透视辅助!WPK辅助软件,wp... 透视辅助!WPK辅助软件,wpk盈利一直真的有挂(详细真的有外卦挂教程)1、进入到黑科技之后,能看到...
透视辅助!wpK好像有挂,wp... 透视辅助!wpK好像有挂,wpk私人局原来真的有挂(详细德州透视辅助教程)一、AI软件牌型概率发牌机...
黑科技辅助挂!wepoke黑科... 您好,wepoke黑科技这款游戏可以开挂的,确实是有挂的,需要了解加微【136704302】很多玩家...
6分钟了解!微扑克辅助技巧,微... 6分钟了解!微扑克辅助技巧,微扑克智能一直存在有挂(详细wpk透视辅助教程)在进入wpk透视辅助辅助...
每日必看推荐!德扑之星开桌怎么... 每日必看推荐!德扑之星开桌怎么设置,德扑ai购买果然有挂(详细手机上教程)1、这是跨平台的黑科技,在...
黑科技透明挂!wepoke透明... 黑科技透明挂!wepoke透明挂辅助器,Wepoke数据一贯是真的有挂(详细辅助挂教程)进入游戏-大...