Go | Gin 解决跨域问题跨域配置

<h1> Go | Gin 解决跨域问题跨域配置 </h1>nginx

前言

在先后端分离的项目中,常常会遇到跨域问题,遇到问题该如何解决呢?!git

1、关于跨域解决方案

关于跨域的解决方法,大部分能够分为 2 种github

  1. nginx反向代理解决跨域
  2. 服务端设置Response Header(响应头部)的Access-Control-Allow-Origin

对于后端开发来讲,第 2 种的操做性更新灵活,这里也讲一下 Gin 是如何作到的后端

2、使用步骤

在 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()) 在使用路由前进行设置,不然会致使不生效spa

反例代理

r := gin.Default()

pingGroup := r.Group("ping")
{
    pingGroup.GET("/", Ping)
}

r.Use(middlewares.Cors())

这样会致使跨域配置不生效code

image

相关文章
相关标签/搜索