Angular 및 Go에서 인증 헤더 처리
Angular HTTP 요청에 인증 헤더를 추가하려면 HTTP 인터셉터 활용을 고려하세요. 각 요청에 헤더를 추가할 수 있으며 Guards는 경로 보호에 사용될 수 있습니다.
Angular HTTP 인터셉터 예:
// auth.interceptor.ts import { HttpEvent, HttpHandler, HttpInterceptor, HttpRequest } from '@angular/common/http'; import { Injectable } from '@angular/core'; import { Observable } from 'rxjs/Observable'; import { AuthService } from './auth.service'; @Injectable() export class AuthInterceptor implements HttpInterceptor { intercept(req: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>> { req = req.clone({ setHeaders: { 'Content-Type': 'application/json; charset=utf-8', 'Accept': 'application/json', 'Authorization': `Bearer ${AuthService.getToken()}`, }, }); return next.handle(req); } }
인터셉터를 app.module.ts의 공급자:
// app.module.ts import { HTTP_INTERCEPTORS, HttpClientModule } from '@angular/common/http'; import { AuthInterceptor } from '../auth/auth.interceptor'; ... imports: [ HttpClientModule, ... ], providers: [ { provide: HTTP_INTERCEPTORS, useClass: AuthInterceptor, multi: true, }, ... ], ...
Go CORS 구성:
Go에서 CORS 구성이 클라이언트가 보낸 HTTP 헤더와 일치하는지 확인하세요. 필요한 경우 모든 헤더를 허용합니다.
headersOk := handlers.AllowedHeaders([]string{"*"}) originsOk := handlers.AllowedOrigins([]string{"*"}) methodsOk := handlers.AllowedMethods([]string{"GET", "HEAD", "POST", "PUT", "OPTIONS"})
Chrome 개발자 도구에서 헤더를 검사하고 클라이언트 헤더에 맞게 CORS 설정을 신중하게 재구성하는 것을 고려하세요. 이렇게 하면 현재 겪고 있는 CORS 문제가 해결됩니다.
위 내용은 Go에서 Angular HTTP 요청을 보호하고 CORS를 처리하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!