在Angular中,您可以使用JWT拦截器来检查JWT令牌是否过期,并在过期时发送通知。您还可以使用Angular的订阅机制来监视用户身份验证状态的更改,并在状态更改时发送通知。
下面是一个示例,演示如何使用JWT拦截器和订阅机制来实现此目的:
首先,创建一个JWT拦截器,用于检查JWT令牌是否过期:
import { Injectable } from '@angular/core'; import { HttpInterceptor, HttpRequest, HttpHandler, HttpEvent } from '@angular/common/http'; import { Observable } from 'rxjs/Observable'; import 'rxjs/add/operator/do';
@Injectable()
export class JwtInterceptor implements HttpInterceptor {
intercept(request: HttpRequestBearer ${currentUser.token}
}
});
}
return next.handle(request).do((event: HttpEvent) => {}, (err: any) => {
if (err.status === 401) {
// JWT token has expired - notify subscribers
AuthenticationService.isAuthenticated.next(false);
}
});
} }
在上述拦截器中,我们使用do操作符来订阅HTTP请求。如果服务器返回401未授权错误,则推送false给认证状态的主题。
接下来,您可以创建一个名为“AuthenticationService”的共享服务。它将作为用于控制身份验证状态的中介,并将持有可观察对象,以供组件订阅认证状态的变化:
import { Injectable } from '@angular/core';
import { BehaviorSubject } from 'rxjs/BehaviorSubject';
@Injectable()
export class AuthenticationService {
public static isAuthenticated: BehaviorSubject
在您的组件中,您可以订阅AuthenticationService中的isAuthenticated主题,以便在用户身份验证状态更改时得到通知:
import { Component, OnInit } from '@angular/core'; import { AuthenticationService } from './authentication.service';
@Component({ selector: 'app-main', templateUrl: './main.component.html', styleUrls: ['./main.component.css'] }) export class MainComponent implements OnInit { isAuthenticated: boolean; constructor