使用Go语言实现跨域资源共享(CORS)设置

 更新时间:2024年06月05日 10:24:56   作者:程序员墨松  
在Web开发中,跨域资源共享(CORS)是一种重要的安全机制,它允许许多资源在一个网页上被另一个来源的网页所访问,然而,出于安全考虑,浏览器默认禁止这种跨域访问,为了解决这个问题,我们可以使用Go语言来设置CORS,需要的朋友可以参考下

如何使用Go语言进行跨域资源共享(CORS)设置?

在Web开发中,跨域资源共享(CORS)是一种重要的安全机制,它允许许多资源(例如字体、JavaScript等)在一个网页上被另一个来源的网页所访问。然而,出于安全考虑,浏览器默认禁止这种跨域访问。为了解决这个问题,我们可以使用Go语言来设置CORS。

为什么需要设置CORS?

在Web应用中,我们经常会遇到这样的场景:一个网页需要从另一个来源获取资源,例如从CDN加载图片或JavaScript文件,或者从一个API服务获取数据。由于浏览器的同源策略限制,这些跨域请求默认会被阻止。CORS机制就是为了解决这个问题而设计的,它允许服务器明确指示哪些来源的网页可以访问其资源。

如何使用Go语言设置CORS?

在Go语言中,设置CORS通常涉及到在HTTP响应头中设置适当的CORS相关头信息。以下是一个简单的示例,展示了如何在Go的HTTP服务器中设置CORS:

package main

import (
 "fmt"
 "net/http"
)

func corsHandler(w http.ResponseWriter, r *http.Request) {
 // 设置允许跨域访问的来源
 w.Header().Set("Access-Control-Allow-Origin", "*")

 // 设置允许的请求方法
 w.Header().Set("Access-Control-Allow-Methods", "POST, GET, OPTIONS, PUT, DELETE")

 // 设置允许的请求头
 w.Header().Set("Access-Control-Allow-Headers", "Accept, Content-Type, Content-Length, Accept-Encoding, X-CSRF-Token, Authorization")

 // 预检请求的缓存时间(秒)
 w.Header().Set("Access-Control-Max-Age", "86400")

 // 是否允许携带凭证
 w.Header().Set("Access-Control-Allow-Credentials", "true")

 // 处理实际的请求
 // ...
}

func main() {
 http.HandleFunc("/", corsHandler)
 http.ListenAndServe(":8080", nil)
}

在这个示例中,我们定义了一个corsHandler函数,它会在每个响应中设置CORS相关的头信息。然后,我们将这个函数注册为处理根路径(“/”)的处理器。

  • Access-Control-Allow-Origin:指定哪些来源的网页可以访问该资源。在这个例子中,我们设置为"*",表示允许所有来源的访问。在实际应用中,为了安全起见,你应该明确指定允许访问的来源。
  • Access-Control-Allow-Methods:指定允许的HTTP请求方法,如GET、POST等。
  • Access-Control-Allow-Headers:指定允许的请求头。
  • Access-Control-Max-Age:指定预检请求的缓存时间(以秒为单位)。这可以减少不必要的预检请求。
  • Access-Control-Allow-Credentials:指定是否允许携带凭证(如cookies、HTTP认证等)。

请注意,这只是一个简单的示例,用于说明如何在Go语言中设置CORS。在实际应用中,你可能需要根据具体需求进行更复杂的配置。此外,你还可以考虑使用第三方库(如gorilla/mux、chirouter等)来更方便地管理CORS设置。

拓展知识:Go实现CORS(跨域)

实现原理

跨域资源共享标准描述了,新的HTTP头部在浏览器有权限的时候,应该以如何的形式发送请求到远程URLs。虽然服务器会有一些校验和认证,但是浏览器有责任去支持这些头部以及增加相关的限制。对于能够修改数据的Ajax和HTTP请求方法(特别是 GET 以外的 HTTP 请求,或者搭配某些 MIME 类型的 POST 请求),浏览器必须首先使用 OPTIONS 方法发起一个预检请求(preflight request),从而获知服务端是否允许该跨源请求。服务器确认允许之后,才发起实际的 HTTP 请求。在预检请求的返回中,服务器端也可以通知客户端,是否需要携带身份凭证(包括 Cookies 和 HTTP 认证相关数据)。

Go是如何实现

在Golang中,可以使用HTTP处理程序和中间件来实现CORS。接着我们以Gin为例

package main

import (
	"github.com/gin-gonic/gin"
	"net/http"
)

func main() {
	router := gin.Default()

	// CORS中间件
	cors := func(c *gin.Context) {
		// 允许特定的域进行跨域请求
		c.Writer.Header().Set("Access-Control-Allow-Origin", "http://mysite.vip")
		// 允许特定的请求方法
		c.Writer.Header().Set("Access-Control-Allow-Methods", "GET, POST, PUT, DELETE")
		// 允许特定的请求头
		c.Writer.Header().Set("Access-Control-Allow-Headers", "Content-Type, Authorization")
		// 允许携带身份凭证(如Cookie)
		c.Writer.Header().Set("Access-Control-Allow-Credentials", "true")
		// 继续处理请求
		c.Next()
	}

	// 应用CORS中间件到所有路由
	router.Use(cors)

	// 定义一个路由和处理器函数
	router.GET("/hello-world", func(c *gin.Context) {
		c.String(http.StatusOK, "Hello, World!")
	})
	router.Run(":8080")
}

输出

[GIN-debug] GET /hello-world --> main.main.func2 (4 handlers)
[GIN-debug] Listening and serving HTTP on :8080

在上例中,设置了Access-Control-Allow-Origin响应头,指定允许跨域请求的域名。您可以根据需要设置为特定域名、通配符*(允许所有域名)或动态获取请求头中的Origin值。另外,还设置了允许的请求方法、请求头以及是否允许携带身份凭证(如Cookie)。

测试

这里通过命令行curl来验证,如果返回结果中出现 CORS 相关的 header( ccess-Control-Allow-Origin: * < Access-Control-Allow-Methods: * < Access-Control-Allow-Headers: * < Access-Control-Expose-Headers: * < Access-Control-Max-Age: 5 ),则跨域成功。结果如下:

#curl -i -k http://127.0.0.1:8080/hello-world
HTTP/1.1 200 OK
Access-Control-Allow-Credentials: true
Access-Control-Allow-Headers: Content-Type, Authorization
Access-Control-Allow-Methods: GET, POST, PUT, DELETE
Access-Control-Allow-Origin: http://mysite.vip
Content-Type: text/plain; charset=utf-8
Date: Sat, 14 Oct 2023 13:42:35 GMT
Content-Length: 13

Hello, World!

到此这篇关于使用Go语言实现跨域资源共享(CORS)设置的文章就介绍到这了,更多相关Go设置CORS内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Go语言实现JSON解析的方法详解

    Go语言实现JSON解析的方法详解

    在日常项目中,使用Json格式进行数据封装是比较常见的操作。本文将详细讲解如何利用Go语言实现JSON的解析,感兴趣的小伙伴可以学习一下
    2022-04-04
  • Go 语言入门学习之正则表达式

    Go 语言入门学习之正则表达式

    这篇文章主要介绍了Go 语言入门学习之正则表达式,文章基于GO语言的相关资料展开详细内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下
    2022-04-04
  • 深入了解GoLang中的工厂设计模式

    深入了解GoLang中的工厂设计模式

    这篇文章主要介绍了深入了解GoLang中的工厂设计模式,工厂模式是一种常用的设计模式,它属于创建型模式,它的主要目的是封装对象的创建过程,将对象的创建过程与对象的使用过程分离,从而提高代码的可维护性和可扩展性,需要详细了解可以参考下文
    2023-05-05
  • Go每日一库之dateparse处理时间

    Go每日一库之dateparse处理时间

    不管什么时候,处理时间总是让人头疼的一件事情。今天要介绍的dateparse实现解析日期时间格式的字符串。具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-07-07
  • go mod tidy报错:zip: not a valid zip file解决办法

    go mod tidy报错:zip: not a valid zip file解决办法

    这篇文章主要给大家介绍了关于go mod tidy报错:zip: not a valid zip file的解决办法,go mod是进行代码管理,这错误是因为本地分支和远程分支冲突,本文通过代码介绍的非常详细,需要的朋友可以参考下
    2024-01-01
  • go语言操作redis连接池的方法

    go语言操作redis连接池的方法

    这篇文章主要介绍了go语言操作redis连接池的方法,涉及Go语言操作radis的技巧,需要的朋友可以参考下
    2015-03-03
  • Go设计模式之单例模式图文详解

    Go设计模式之单例模式图文详解

    单例模式是一种创建型设计模式,让你能够保证一个类只有一个实例,并提供一个访问该实例的全局节点,本文就通过图文给大家介绍一下Go的单例模式,需要的朋友可以参考下
    2023-07-07
  • go语言中切片Slice与数组Array对比以及panic: runtime error: index out of range问题解决

    go语言中切片Slice与数组Array对比以及panic: runtime error: index out 

    go语言中数组与其他语言有在显著的不同,包括其不能够进行添加,以及值拷贝的特性,下面这篇文章主要给大家介绍了关于go语言中切片Slice与数组Array对比以及panic: runtime error: index out of range问题解决的相关资料,需要的朋友可以参考下
    2022-07-07
  • Go一站式配置管理工具Viper的使用教程

    Go一站式配置管理工具Viper的使用教程

    Viper是一个方便Go语言应用程序处理配置信息的库,它可以处理多种格式的配置,这篇文章主要为大家介绍了它的具体使用教程,需要的可以参考下
    2023-08-08
  • Golang基础学习之map的示例详解

    Golang基础学习之map的示例详解

    哈希表是常见的数据结构,有的语言会将哈希称作字典或者映射,在Go中,哈希就是常见的数据类型map,本文就来聊聊Golang中map的相关知识吧
    2023-03-03

最新评论