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