[Go] CORS 支持多個 origin 訪問的思路 (Access-Control-Allow-Origin 部分)


 

以下為局部偽代碼,僅供參考:

var allowOrigin string
allowOrigins := config.AppConf.Get("middleware.cors.allowOrigins").(string)

if strings.Contains(allowOrigins, "*") {
    allowOrigin = "*"
} else {
    origin := c.GetHeader("Origin")
    if strings.Contains(allowOrigins, origin) {
        allowOrigin = origin
    }
}

if allowOrigin != "" {
    c.Writer.Header().Set("Access-Control-Allow-Origin", allowOrigin)
}

 

思路是,配置中如果配置了允許任何域名跨域訪問,則設置 Access-Control-Allow-Origin 為 “*”。

其次如果當前 origin 被允許,那么設置 Access-Control-Allow-Origin 為當前 origin。

其余情況不設置 Access-Control-Allow-Origin。

 

[Go] httprouter 自動 OPTIONS 響應 和 CORS

[Go] Viper 加載項目配置,go build 打包配置文件進二進制  

 

Ref:https://github.com/gopher-lego/skeleton/

Link:https://www.cnblogs.com/farwish/p/12985127.html 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM