>백엔드 개발 >Golang >Go의 Gin 프레임워크에서 CORS 미들웨어를 올바르게 구성하는 방법은 무엇입니까?

Go의 Gin 프레임워크에서 CORS 미들웨어를 올바르게 구성하는 방법은 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2024-12-23 03:00:54214검색

How to Properly Configure CORS Middleware in Go's Gin Framework?

Go Gin 프레임워크: CORS(Cross-Origin Resource Sharing) 처리

Go의 gin 프레임워크에서 CORS(Cross-Origin Resource Sharing)를 구성하면 다양한 출처의 클라이언트가 허용됩니다. 귀하의 리소스에 액세스합니다. 그러나 OPTIONS 요청을 보낸 후 빈 응답을 경험한 사용자의 경우처럼 CORS 요청이 예상한 동작을 반환하지 않는 문제가 발생할 수 있습니다.

이 문제를 해결하기 위해 사용자의 미들웨어를 제공하고 이를 작동하는 것과 비교 예:

func CORSMiddleware() gin.HandlerFunc {
    return func(c *gin.Context) {
        c.Writer.Header().Set("Content-Type", "application/json")
        c.Writer.Header().Set("Access-Control-Allow-Origin", "*")
        c.Writer.Header().Set("Access-Control-Max-Age", "86400")
        c.Writer.Header().Set("Access-Control-Allow-Methods", "POST, GET, OPTIONS, PUT, DELETE, UPDATE")
        c.Writer.Header().Set("Access-Control-Allow-Headers", "Content-Type, Content-Length, Accept-Encoding, X-CSRF-Token, Authorization, X-Max")
        c.Writer.Header().Set("Access-Control-Allow-Credentials", "true")

        if c.Request.Method == "OPTIONS" {
            c.AbortWithStatus(200)
        } else {
            c.Next()
        }
    }
}
func CORSMiddleware() gin.HandlerFunc {
    return func(c *gin.Context) {
        c.Writer.Header().Set("Access-Control-Allow-Origin", "*")
        c.Writer.Header().Set("Access-Control-Allow-Credentials", "true")
        c.Writer.Header().Set("Access-Control-Allow-Headers", "Content-Type, Content-Length, Accept-Encoding, X-CSRF-Token, Authorization, accept, origin, Cache-Control, X-Requested-With")
        c.Writer.Header().Set("Access-Control-Allow-Methods", "POST, OPTIONS, GET, PUT")

        if c.Request.Method == "OPTIONS" {
            c.AbortWithStatus(204)
            return
        }

        c.Next()
    }
}

차이점:

  • 중단 상태 코드: 작업 중인 미들웨어가 상태 코드로 중단됩니다. OPTIONS 요청의 경우 204(콘텐츠 없음)이고 사용자의 미들웨어는 다음과 같이 중단됩니다. 200(OK).
  • 허용되는 메서드: 작동하는 미들웨어는 POST, OPTIONS, GET 및 PUT 메서드만 허용하는 반면, 사용자의 미들웨어에는 DELETE 및 UPDATE가 포함됩니다.

따라서 문제를 해결하려면 사용자는 특히 중단을 수정하여 작업 예제와 일치하도록 미들웨어를 업데이트해야 합니다. 상태 코드 및 허용 방법을 조정합니다.

위 내용은 Go의 Gin 프레임워크에서 CORS 미들웨어를 올바르게 구성하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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