AngularOAuth2OidcBearerTokenisinoneoutoftwoserviceinstancesrequests?
创始人
2024-10-28 19:00:43
0
  1. 在app.module.ts文件中导入OAuthModule和HttpClientModule。

import { HttpClientModule } from '@angular/common/http'; import { OAuthModule } from 'angular-oauth2-oidc'; ...

@NgModule({ imports: [ HttpClientModule, ... OAuthModule.forRoot() ], ... })

  1. 在Service中使用OAuthService手动设置accessToken,并在请求的headers中添加Authorization。

import { Injectable } from '@angular/core'; import { HttpClient, HttpHeaders } from '@angular/common/http'; import { OAuthService } from 'angular-oauth2-oidc';

@Injectable({ providedIn: 'root' }) export class MyService { constructor(private http: HttpClient, private oauthService: OAuthService) {}

getData() { const token = this.oauthService.getAccessToken();

const httpOptions = {
  headers: new HttpHeaders({
    'Content-Type': 'application/json',
    Authorization: 'Bearer ' + token
  })
};

return this.http.get('/api/data', httpOptions);

} }

  1. 在拦截器中使用OAuthService自动添加accessToken到请求headers中。

import { Injectable } from '@angular/core'; import { HttpEvent, HttpHandler, HttpInterceptor, HttpRequest } from '@angular/common/http'; import { Observable } from 'rxjs'; import { OAuthService } from 'angular-oauth2-oidc';

@Injectable() export class TokenInterceptor implements HttpInterceptor { constructor(private oauthService: OAuthService) {}

intercept(request: HttpRequest, next: HttpHandler): Observable> { const token = this.oauthService.getAccessToken();

if (token) {
  request = request.clone({
    setHeaders: {
      Authorization: `Bearer ${token}`
    }
  });
}

return next.handle(request);

} }

  1. 在app.module.ts中注册拦截器。

import { HttpClientModule, HTTP_INTERCEPTORS } from '@angular/common/http'; import { OAuthModule } from 'angular-oauth2-oidc'; import { TokenInterceptor } from './token-interceptor';

...

@NgModule({ imports: [ HttpClientModule, ... OAuthModule.forRoot() ], ... providers: [ { provide: HTTP_INTERCEPTORS, useClass: TokenInterceptor, multi: true } ] })

这些解决方案将确保OAuth2 OIDC Bearer Token可以在服务请求中正确使用。

相关内容

热门资讯

透视指南!拱趴大菠萝挂怎么安装... 透视指南!拱趴大菠萝挂怎么安装(透视)约局吧德州透视(辅助)真是真的有技巧(哔哩哔哩)1.拱趴大菠萝...
透视项目!佛手在线大菠萝辅助(... 透视项目!佛手在线大菠萝辅助(透视)xpoker辅助器(辅助)竟然真的是有插件(哔哩哔哩)1、不需要...
透视诀窍!大菠萝辅助器(透视)... 透视诀窍!大菠萝辅助器(透视)约局吧德州真的存在透视吗(辅助)本来是有插件(哔哩哔哩)1)约局吧德州...
透视指南!德扑圈透视挂(WeP... 透视指南!德扑圈透视挂(WePoKer辅助挂)一直是有辅助插件(哔哩哔哩)1、打开软件启动之后找到中...
透视大纲!wepoker究竟有... 透视大纲!wepoker究竟有没有透视(WePoKer正版)果然存在有辅助教程(哔哩哔哩)一、wep...
透视模块!聚星ai辅助工具激活... 透视模块!聚星ai辅助工具激活码(透视)pokemmo辅助脚本(辅助)果然一直都是有脚本(哔哩哔哩)...
透视方式!wepoker游戏安... 透视方式!wepoker游戏安装教程(WePoKer分析器)总是真的有辅助技巧(哔哩哔哩);1、下载...
透视资料!菠萝辅助器免费版的功... 透视资料!菠萝辅助器免费版的功能介绍(透视)福建大菠萝万能辅助器(辅助)一贯是真的有脚本(哔哩哔哩)...
透视窍要!哈糖大菠萝可以开挂吗... 透视窍要!哈糖大菠萝可以开挂吗(WPK控制牌)都是真的有辅助工具(哔哩哔哩)1、该软件可以轻松地帮助...
透视模块!hhpoker是真的... 透视模块!hhpoker是真的吗(HHpoker机器人)本来是真的有辅助技巧(哔哩哔哩)在进入hhp...