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、在德扑之星如...
黑科技讲解!wepoke有软件... 黑科技讲解!wepoke有软件吗(透视)原先是有挂(有挂插件挂)-哔哩哔哩;最新版2024是一款经典...
黑科技透明!红龙扑克是正规的吗... 黑科技透明!红龙扑克是正规的吗(黑科技ai)太坑了真的是有挂(德州教程黑科技教程)-哔哩哔哩1、许多...
黑科技了解!德扑ai智能机器人... 1、黑科技了解!德扑ai智能机器人代理(透视)确实真的是有挂(有挂安装)-哔哩哔哩(UU poker...
黑科技安卓版!wopoker手... 黑科技安卓版!wopoker手机辅助(ai代打)太坑了真的有挂(AI教程黑科技工具)-哔哩哔哩1、完...
黑科技总结!aa poker智... 黑科技总结!aa poker智能ai辅助介绍(黑科技ai)切实存在有挂(有挂安装)-哔哩哔哩关于aa...
黑科技安装!aapoker有后... 黑科技安装!aapoker有后台操控吗(智能ai)太坑了真的有挂(黑科技教程黑科技辅助)-哔哩哔哩;...
黑科技ai代打!苹果菠萝德州辅... 黑科技ai代打!苹果菠萝德州辅助神器(智能ai)原生是有挂(有挂测试)-哔哩哔哩;最新版2024是一...
黑科技安卓版!wepoke a... 黑科技安卓版!wepoke app(透视)太坑了是有挂(曝光教程黑科技解密)-哔哩哔哩;一、wepo...
黑科技苹果版!哈糖大菠萝切牌规... 黑科技苹果版!哈糖大菠萝切牌规律(辅助挂)先前是有挂(有挂后台)-哔哩哔哩;亲真的是有正版授权,小编...