共计 1185 个字符,预计需要花费 3 分钟才能阅读完成。
<h1> Go | Gin 解决跨域问题跨域配置 </h1>
前言
在前后端拆散的我的项目中,常常会遇到跨域问题,遇到问题该如何解决呢?!
一、对于跨域解决方案
对于跨域的解决办法,大部分能够分为 2 种
- nginx 反向代理解决跨域
- 服务端设置 Response Header(响应头部) 的
Access-Control-Allow-Origin
对于后端开发来说,第 2 种的操作性更新灵便,这里也讲一下 Gin 是如何做到的
二、应用步骤
在 Gin 中提供了 middleware (中间件) 来做到在一个申请前后解决响应的逻辑,这里咱们应用两头来做到在每次申请是增加上 Access-Control-Allow-Origin
头部
1. 编写一个中间件
能够 middlewares
包下创立
package middlewares
import (
"github.com/gin-gonic/gin"
"net/http"
)
func Cors() gin.HandlerFunc {return func(c *gin.Context) {
method := c.Request.Method
if origin != "" {
// 可将将 * 替换为指定的域名
c.Header("Access-Control-Allow-Origin", "*")
c.Header("Access-Control-Allow-Methods", "POST, GET, OPTIONS, PUT, DELETE, UPDATE")
c.Header("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept, Authorization")
c.Header("Access-Control-Expose-Headers", "Content-Length, Access-Control-Allow-Origin, Access-Control-Allow-Headers, Cache-Control, Content-Language, Content-Type")
c.Header("Access-Control-Allow-Credentials", "true")
}
if method == "OPTIONS" {c.AbortWithStatus(http.StatusNoContent)
}
c.Next()}
}
2. 应用
r := gin.Default()
r.Use(middlewares.Cors())
3. 注意事项
须要将 r.Use(middlewares.Cors())
在应用路由前进行设置,否则会导致不失效
反例
r := gin.Default()
pingGroup := r.Group("ping")
{pingGroup.GET("/", Ping)
}
r.Use(middlewares.Cors())
这样会导致跨域配置不失效
正文完