>백엔드 개발 >Golang >Go 미들웨어는 CORS에 대한 실행 전 요청 처리를 어떻게 단순화할 수 있나요?

Go 미들웨어는 CORS에 대한 실행 전 요청 처리를 어떻게 단순화할 수 있나요?

Linda Hamilton
Linda Hamilton원래의
2024-12-18 03:33:21906검색

How Can Go Middleware Simplify Preflight Request Handling for CORS?

Go for CORS의 실행 전 요청 처리

CORS(Cross-Origin Resource Sharing)에서는 종종 브라우저가 실행 전 OPTIONS 요청을 보내 다음 여부를 확인하도록 요구합니다. 실제 요청을 보내도 안전합니다. Go에서 이러한 실행 전 요청을 효율적으로 처리하는 것은 어려울 수 있습니다.

한 가지 접근 방식은 표준 net/http 패키지를 사용하여 처리기 기능 내에서 요청 메서드를 확인하는 것입니다. 그러나 이는 특히 여러 핸들러의 경우 지루할 수 있습니다.

또는 Gorilla의 mux 패키지가 더 깔끔한 솔루션을 제공합니다. 각 관련 URL 경로에 대해 별도의 "OPTIONS" 처리기를 등록할 수 있습니다. 두 가지 방법 모두 실행 가능하지만 항상 가장 멋진 방법은 아닙니다.

미들웨어를 사용한 향상된 솔루션

더 단순화하려면 미들웨어 접근 방식을 사용하는 것이 좋습니다. REST 핸들러를 미들웨어 기능으로 래핑하면 실제 요청 처리에서 CORS 처리 논리를 분리할 수 있습니다. 예를 들어, net/http를 사용하면

func corsHandler(h http.Handler) http.HandlerFunc {
  return func(w http.ResponseWriter, r *http.Request) {
    if (r.Method == "OPTIONS") {
      // Handle preflight here
    } else {
      h.ServeHTTP(w,r)
    }
  }
}

다음과 같이 REST 핸들러를 래핑할 수 있습니다.

http.Handle("/endpoint/", corsHandler(restHandler))

이 접근 방식은 실행 전 요청을 처리하는 깨끗하고 재사용 가능한 방법을 제공합니다. 원활한 교차 출처 상호 작용을 보장하면서 비즈니스 논리에 집중할 수 있습니다.

위 내용은 Go 미들웨어는 CORS에 대한 실행 전 요청 처리를 어떻게 단순화할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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