>백엔드 개발 >Golang >Go에서 Angular HTTP 요청을 보호하고 CORS를 처리하는 방법은 무엇입니까?

Go에서 Angular HTTP 요청을 보호하고 CORS를 처리하는 방법은 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2024-12-13 21:25:12299검색

How to Secure Angular HTTP Requests and Handle CORS in Go?

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.