通过 Golang 框架实现自定义 CORS 过滤器:创建并注册自定义过滤器,设置 CORS 标头。添加过滤器到 Gin 路由器。当向服务器发出跨域请求时,它将返回允许浏览器的 CORS 标头。根据需要限制 Access-Control-Allow-Origin 和 Access-Control-Allow-Headers 标头,并考虑使用 OPTIONS 方法处理预检请求。
通过 Golang 框架实现自定义跨域资源共享 (CORS) 过滤器
前言
跨域资源共享 (CORS) 是一种允许浏览器跨域请求资源的 HTTP 机制。在 Golang 中,可以通过实现过滤器轻松实现自定义 CORS 策略。
自定义 CORS 过滤器
首先,创建并注册一个自定义过滤器:
// corsFilter.go package main import ( "net/http" "github.com/gin-gonic/gin" ) // CORSFilter adds CORS headers to the response. func CORSFilter() gin.HandlerFunc { return func(c *gin.Context) { c.Writer.Header().Set("Access-Control-Allow-Origin", "*") c.Writer.Header().Set("Access-Control-Allow-Methods", "POST, GET, OPTIONS, PUT, DELETE") c.Writer.Header().Set("Access-Control-Allow-Headers", "*") } } func main() { router := gin.Default() router.Use(CORSFilter()) // 注册您的路由... }
实战案例
假设您有一个 Gin 路由器,以下是添加自定义 CORS 过滤器的示例:
// main.go package main import ( "net/http" "github.com/gin-gonic/gin" ) func main() { router := gin.Default() router.Use(CORSFilter()) router.GET("/", func(c *gin.Context) { c.JSON(http.StatusOK, gin.H{"message": "Hello World!"}) }) router.Run(":8080") }
这样,当您向服务器发出跨域请求时,它将返回允许浏览器的 CORS 标头。您可以根据业务需求自定义 CORS 设置。
注意事项
Access-Control-Allow-Origin
和 Access-Control-Allow-Headers
标头。