通过 golang 框架实现自定义 cors 过滤器:创建并注册自定义过滤器,设置 cors 标头。添加过滤器到 gin 路由器。当向服务器发出跨域请求时,它将返回允许浏览器的 cors 标头。根据需要限制 access-control-allow-origin 和 access-control-allow-headers 标头,并考虑使用 options 方法处理预检请求。
通过 Golang 框架实现自定义跨域资源共享 (CORS) 过滤器
前言
跨域资源共享 (CORS) 是一种允许浏览器跨域请求资源的 HTTP 机制。在 Golang 中,可以通过实现过滤器轻松实现自定义 CORS 策略。
立即学习“go语言免费学习笔记(深入)”;
自定义 CORS 过滤器
首先,创建并注册一个自定义过滤器:
// corsFilter.go
package main
import (
"net/http"
"<a style='color:#f60; text-decoration:underline;' href="https://www.php.cn/zt/15841.html" target="_blank">git</a>hub.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 标头。
- 考虑使用 OPTIONS 方法来处理预检请求。