1
0

middlewares.go 1.2 KB

123456789101112131415161718192021222324252627282930313233
  1. package core
  2. import "github.com/gin-gonic/gin"
  3. func CorsMiddleWare() gin.HandlerFunc {
  4. return func(context *gin.Context) {
  5. method := context.Request.Method
  6. origin := context.Request.Header.Get("Origin") //请求头部
  7. if origin != "" {
  8. //接收客户端发送的origin (重要!)
  9. context.Writer.Header().Set("Access-Control-Allow-Origin", "*")
  10. //服务器支持的所有跨域请求的方法
  11. context.Header("Access-Control-Allow-Methods", "POST, GET, OPTIONS, PUT, DELETE,UPDATE")
  12. //允许跨域设置可以返回其他子段,可以自定义字段
  13. context.Header("Access-Control-Allow-Headers", "Authorization, Content-Length, X-CSRF-Token, Token,session")
  14. // 允许浏览器(客户端)可以解析的头部 (重要)
  15. context.Header("Access-Control-Expose-Headers", "Content-Length, Access-Control-Allow-Origin, Access-Control-Allow-Headers")
  16. //设置缓存时间
  17. //c.Header("Access-Control-Max-Age", "172800")
  18. //允许客户端传递校验信息比如 cookie (重要)
  19. context.Header("Access-Control-Allow-Credentials", "true")
  20. }
  21. //允许类型校验
  22. if method == "OPTIONS" {
  23. context.AbortWithStatus(200)
  24. } else {
  25. context.Next()
  26. }
  27. }
  28. }