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可以在服务请求中正确使用。

相关内容

热门资讯

重磅来袭“玄龙大厅怎么开辅助”... 玄龙大厅怎么开辅助是一款可以让一直输的玩家,快速成为一个“必胜”的ai辅助神器,有需要的用户可以加我...
查到实测“破解大菠萝的辅助器”... 破解大菠萝的辅助器是一款专注玩家量身打造的游戏记牌类型软件,在破解大菠萝的辅助器这款游戏中我们可以记...
玩家爆料“指尖辅助”本来有开挂... 指尖辅助是一款可以让一直输的玩家,快速成为一个“必胜”的ai辅助神器,有需要的用户可以加我微信(13...
揭秘攻略“心悦怎么开挂”一向有... 心悦怎么开挂是一款专注玩家量身打造的游戏记牌类型软件,在心悦怎么开挂这款游戏中我们可以记录下每张牌的...
新手必备“九游辅助辅助在哪里”... 您好:这款九游辅助辅助在哪里游戏是可以开挂的,确实是有挂的,很多玩家在这款九游辅助辅助在哪里游戏中打...
透视代打!吉祥填大坑插件,德州... 您好:这款德州辅助工具到底怎么样游戏是可以开挂的,确实是有挂的,很多玩家在这款德州辅助工具到底怎么样...
透视脚本!顺欣茶楼辅助软件视频... 透视脚本!顺欣茶楼辅助软件视频,如何下载德普之星辅助软件(辅助挂)详细开挂辅助软件;亲,如何下载德普...
透视存在!指尖四川小程序辅助器... 指尖四川小程序辅助器是一款专注玩家量身打造的游戏记牌类型软件,在指尖四川小程序辅助器这款游戏中我们可...
透明神器!wepoker辅助是... 透明神器!wepoker辅助是真的假的,wepoker黑侠破解(辅助挂)详细开挂辅助挂;无需打开直接...
透视能赢!wepoker好友房... 透视能赢!wepoker好友房开挂,aapoker辅助插件工具(辅助挂)详细开挂辅助神器;无需打开直...