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

相关内容

热门资讯

透视能赢!wejoker辅助脚... 透视能赢!wejoker辅助脚本,we poker辅助器v3.3(透视)AA德州教程(有挂工具)1、...
透视教学!wepoker有辅助... 透视教学!wepoker有辅助功能吗,wepoker辅助是真的吗(透视)wpk教程(有挂解密);1、...
透视科技!wejoker透视方... 透视科技!wejoker透视方法,wepoker软件靠谱么(透视)细节方法(有挂脚本);1、实时we...
透视工具!竞技联盟破解版最新版... 透视工具!竞技联盟破解版最新版,wepoker游戏安装教程,揭秘教程(有挂规律)1、在竞技联盟破解版...
透视安卓版!wepoker游戏... 透视安卓版!wepoker游戏安装教程,wepoker轻量版透视方法(透视)揭秘教程(有挂教程)1、...
透视脚本!hhpoker透视脚... 透视脚本!hhpoker透视脚本视频,德普之星透视,细节方法(有挂技巧);1、金币登录送、破产送、升...
透视辅助!德普之星辅助工具如何... 透视辅助!德普之星辅助工具如何设置,aapoker怎么设置提高好牌几率,安装教程(有挂详情);在进入...
透视能赢!wepoker作弊辅... 透视能赢!wepoker作弊辅助,wepoker作弊方法(透视)透明挂教程(有挂解密)1)wepok...
透视辅助!wepoker有没有... 透视辅助!wepoker有没有透视方法,wejoker内置辅助,2025新版(有挂秘籍)1、操作简单...
透视软件!wepoker钻石怎... 透视软件!wepoker钻石怎么看底牌,wepoker有人用过吗(透视)黑科技教程(有挂细节)wep...