Go Gin 프레임워크에서 CORS 활성화
Go gin 프레임워크는 앱에서 CORS(Cross-Origin Resource Sharing)를 활성화하기 위한 강력한 미들웨어를 제공합니다. 응용 프로그램. 이 미들웨어를 앱에 추가하면 다양한 출처의 요청이 API 엔드포인트에 액세스하도록 허용할 수 있습니다.
다음 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() } } }
그러나 이 미들웨어를 사용하면 결과가 상태 코드가 200 OK이지만 OPTION 요청 이후 추가 조치가 없으면 중요한 사항을 놓쳤을 수 있습니다. 단계:
수정:
func CORSMiddleware() gin.HandlerFunc {</p> <div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false">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() }
}
pre>
업데이트된 미들웨어에서는 c.AbortWithStatus(204)는 본문 없이 204 No Content 응답 상태를 반환하여 성공적인 OPTIONS 요청을 나타내며 클라이언트가 실제 요청을 진행할 수 있도록 합니다.
위 내용은 OPTIONS 요청을 처리하기 위해 Go Gin에서 CORS 미들웨어를 올바르게 구성하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!