在Angular中,可以使用拦截器来处理HTTP请求和响应。以下是一个示例代码,展示如何在拦截器中使用令牌,并在令牌刷新后更新拦截器中的令牌。
首先,创建一个名为auth.interceptor.ts
的文件,用于实现拦截器逻辑:
import { Injectable } from '@angular/core';
import { HttpInterceptor, HttpRequest, HttpHandler, HttpEvent } from '@angular/common/http';
import { Observable } from 'rxjs';
import { AuthService } from './auth.service';
@Injectable()
export class AuthInterceptor implements HttpInterceptor {
constructor(private authService: AuthService) {}
intercept(request: HttpRequest, next: HttpHandler): Observable> {
// 获取当前令牌
const token = this.authService.getToken();
// 如果令牌存在,则将其添加到请求头中
if (token) {
request = request.clone({
setHeaders: {
Authorization: `Bearer ${token}`
}
});
}
return next.handle(request);
}
}
在上述代码中,AuthInterceptor
类实现了HttpInterceptor
接口,并提供了intercept
方法来处理拦截逻辑。在intercept
方法中,我们首先通过AuthService
服务获取当前的令牌。
然后,我们检查令牌是否存在。如果存在,我们使用clone
方法创建一个新的请求,并在请求头中添加令牌。这样,每个发送的请求都会携带令牌。
接下来,我们需要创建一个名为auth.service.ts
的服务,用于管理令牌的获取和刷新:
import { Injectable } from '@angular/core';
import { BehaviorSubject, Observable } from 'rxjs';
@Injectable({
providedIn: 'root'
})
export class AuthService {
private tokenSubject: BehaviorSubject;
public token$: Observable;
constructor() {
this.tokenSubject = new BehaviorSubject(null);
this.token$ = this.tokenSubject.asObservable();
}
// 获取当前令牌
getToken(): string {
return this.tokenSubject.value;
}
// 刷新令牌
refresh(): Observable {
// 调用令牌刷新接口,获取新的令牌
// 这里使用一个假设的刷新方法,实际中需要根据后端API进行实现
const newToken = 'new_token';
// 更新令牌
this.tokenSubject.next(newToken);
return this.token$; // 返回新的令牌作为Observable
}
}
在上述代码中,AuthService
服务提供了getToken
方法用于获取当前令牌,并提供了refresh
方法用于刷新令牌。在refresh
方法中,我们调用后端API来获取新的令牌,并将其更新到tokenSubject
中。
最后,我们需要在app.module.ts
文件中将拦截器添加到提供者列表中:
import { NgModule } from '@angular/core';
import { HttpClientModule, HTTP_INTERCEPTORS } from '@angular/common/http';
import { AuthInterceptor } from './auth.interceptor';
@NgModule({
imports: [HttpClientModule],
providers: [
{
provide: HTTP_INTERCEPTORS,
useClass: AuthInterceptor,
multi: true
}
]
})
export class AppModule {}
通过将AuthInterceptor
添加到HTTP_INTERCEPTORS
提供者列表中,我们告诉Angular使用该拦截器来处理所有的HTTP请求。
现在,当发送HTTP请求时,拦截器将自动在请求头中添加令牌。如果令牌刷新,你可以调用AuthService
的refresh
方法来更新令牌,并将新令牌发送到拦截器。