Golang 应用程序:请求的资源上不存在'Access-Control-Allow-Origin”标头
每当我尝试从 Angular 应用程序向 Go 服务器发送 HTTP 请求时,我都会收到以下响应:
对预检请求的响应未通过访问控制检查:请求的资源上不存在“Access-Control-Allow-Origin”标头。
我添加了错误响应中详细说明的标头,但错误仍然存在。
服务器.go
package rest import ( "context" "fmt" "net/http" "os" "os/signal" "sync" "syscall" "github.com/gorilla/mux" "github.com/randyVerduguez/randy-verduguez_06122023-BE-challenge/configs" "github.com/randyVerduguez/randy-verduguez_06122023-BE-challenge/http/rest/handlers" "github.com/randyVerduguez/randy-verduguez_06122023-BE-challenge/pkg/db" "github.com/rs/cors" "github.com/sirupsen/logrus" ) type Server struct { logger *logrus.Logger router *mux.Router config configs.Config } func NewServer() (*Server, error) { config, err := configs.NewParsedConfig() if err != nil { return nil, err } database, err := db.Connect(db.ConfigDB{ Host: config.Database.Host, Port: config.Database.Port, User: config.Database.User, Password: config.Database.Password, Name: config.Database.Name, }) if err != nil { return nil, err } log, err := NewLogger() if err != nil { return nil, err } router := mux.NewRouter() handlers.Register(router, log, database) server := Server{ logger: log, config: config, router: router, } return &server, nil } func (s *Server) Run(ctx context.Context) error { cors := cors.New(cors.Options{ AllowedMethods: []string{"GET, POST"}, AllowedOrigins: []string{"http://localhost:4200"}, AllowedHeaders: []string{"Content-Type", "Accept"}, }) server := http.Server{ Addr: fmt.Sprintf(":%d", s.config.ServerPort), Handler: cors.Handler(s.router), } stopServer := make(chan os.Signal, 1) signal.Notify(stopServer, syscall.SIGINT, syscall.SIGTERM) defer signal.Stop(stopServer) serverErrors := make(chan error, 1) var wg sync.WaitGroup wg.Add(1) go func(wg *sync.WaitGroup) { defer wg.Done() s.logger.Printf("REST API listening on %d", s.config.ServerPort) serverErrors <- server.ListenAndServe() }(&wg) select { case err := <-serverErrors: return fmt.Errorf("error: starting REST API server %w", err) case <-stopServer: s.logger.Warn("server recieved STOP signal") err := server.Shutdown(ctx) if err != nil { return fmt.Errorf("graceful shutdown did not complete: %w", err) } wg.Wait() s.logger.Info("server was shutdown gracefully") } return nil } func (s *Server) ServeHTTP(w http.ResponseWriter, r *http.Request) { w.Header().Set("Access-Control-Allow-Origin", "http://localhost:4200") w.Header().Set("Access-Control-Allow-Methods", "POST, GET, OPTIONS") w.Header().Set("Access-Control-Allow-Credentials", "true") w.Header().Set("Access-Control-Allow-Headers", "Content-Type, Content-Length, Accept-Encoding, X-CSRF-Token, Authorization, Accept, origin, Cache-Control, X-Requested-With") if r.Method == "OPTIONS" { return } s.router.ServeHTTP(w, r) }
路线.go
package handlers import ( "net/http" "github.com/gorilla/mux" "github.com/jmoiron/sqlx" "github.com/sirupsen/logrus" ) func Register(r *mux.Router, lg *logrus.Logger, db *sqlx.DB) { handler := newHandler(lg, db) r.Use(handler.MiddlewareLogger()) r.HandleFunc("/weather/current", handler.GetCurrentWeather()).Methods(http.MethodPost) r.HandleFunc("/weather/welcome", handler.Test()).Methods(http.MethodGet) }
正确答案
我注意到的第一个问题是:
AllowedMethods: []string{"GET, POST"},
这应该是:
AllowedMethods: []string{"GET", "POST"},
(或者稍微不易出错的 []string{http.MethodGet, http.MethodPost}
)
根据文档,这是默认值(所以你可以省略它) :
我的下一个问题是“起源是什么”; CORS 是“跨源资源共享”,旨在 “防止从一个源运行的客户端 Web 应用程序获取从另一源检索的数据”,因此了解发出请求的页面的源非常重要。您允许 http://localhost:4200
(AllowedOrigins: []string{"http://localhost:4200"}
) 所以我假设您有两个服务器在本地主机上运行(但如果这不是案件)。如果您希望允许所有来源,请使用 "*"
;为了进行测试,我将使用 test-cors.org - 只需转到该网站,输入 URL,例如“http://127.0.0.1:8080/weather/welcome”,进入“远程URL”,点击“发送请求”进行测试。
您的代码有点令人困惑(例如 (s *Server) ServeHTTP
未使用 - 请旨在提供 最小,可重现的示例,当在这里提问时),所以我稍微简化了一些事情,希望以下内容能为您指明正确的方向。
package main import ( "context" "fmt" "net/http" "github.com/gorilla/mux" "github.com/rs/cors" ) func main() { s, err := NewServer() if err != nil { panic(err) } s.Run(context.Background()) } type Server struct { router *mux.Router } func NewServer() (*Server, error) { router := mux.NewRouter() Register(router) server := Server{ router: router, } return &server, nil } func (s *Server) Run(ctx context.Context) { cors := cors.New(cors.Options{ AllowedMethods: []string{http.MethodGet, http.MethodPost}, AllowedOrigins: []string{"https://www.php.cn/link/9113c52c5f26af1782e6bf7c56973ef4"}, // AllowedOrigins: []string{"*"}, AllowedHeaders: []string{"Content-Type", "Accept"}, }) server := http.Server{ Addr: fmt.Sprintf(":%d", 8080), Handler: cors.Handler(s.router), } fmt.Println(server.ListenAndServe()) } type handler struct{} func Register(r *mux.Router) { handler := handler{} r.HandleFunc("/", handler.Index).Methods(http.MethodGet) r.HandleFunc("/weather/welcome", handler.Test).Methods(http.MethodGet) } // Index - Provide a simple page with a link to the other page to simplify testing func (h *handler) Index(w http.ResponseWriter, _ *http.Request) { w.Write([]byte(`<a href="weather/welcome" >Test Link</a>`)) } // The real page func (h *handler) Test(w http.ResponseWriter, _ *http.Request) { fmt.Println("Test Called") w.Write([]byte("all OK")) }
以上是Golang 应用程序:请求的资源上不存在'Access-Control-Allow-Origin”标头的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

自 2009 年问世以来,比特币成为加密货币界的领头羊,其价格经历了巨大的波动。为了提供全面的历史概述,本文汇集了从 2009 年到 2025 年的比特币价格数据,涵盖了重大的市场事件、市场情绪变化和影响价格走势的重要因素。

1、首先右键点击windows11下方任务栏空白处,选择【任务栏设置】。2、在任务栏设置中找到右侧的【taskbarcorneroverflow】。3、然后在它上方找到【clock】或【时钟】选择开启即可。方法二:1、按下键盘快捷键【win+r】调出运行,输入【regedit】回车确定。2、打开注册表编辑器,在其中找到【HKEY_CURRENT_USERControlPanel】,将它删除。3、删除完了之后重启电脑会提示配置,回到系统就会显示时间了。

解答:以下社区论坛和讨论组可用于解决Java函数式编程问题:StackOverflow:全球最大的编程问答网站,拥有Java函数式编程专家社区。JavaFunctionalProgramming:专注于Java函数式编程的社区论坛,提供有关概念、语言特性和最佳实践的讨论。Redditr/functionaljava:专注于Java函数式编程的subreddit,关注工具、库和技术。Discord:JavaFunctionalProgramming:提供实时讨论、代码分享和协作的Discord服务

如何使用他人的 Python 代码?查找代码库:在 PyPI 和 GitHub 等平台上查找所需代码。安装代码:使用 pip 或克隆 GitHub 仓库进行安装。导入模块:在脚本中使用 import 语句导入已安装的模块。使用代码:访问模块中的函数和类。(可选)调整代码:根据需要修改代码以适应您的项目。

win11电脑时间一直不对怎么办?我们在使用win11系统的时候都会设置时间或者是日历,但是也有不少的用户们在询问电脑的时间一直不对,那么这是怎么回事?用户们可以直接的点击下方的任务栏,然后找到taskbarcorneroverflow来进行设置就可以了。下面就让本站来为用户们来仔细的介绍一下win11电脑时间不对如何调整方法吧。win11电脑时间不对如何调整方法方法一:1、我们首先右键点击下方任务栏空白处,选择任务栏设置。方法二:1、按下键盘快捷键win+r调出运行,输入regedit回车确定

Java函数开发中常见的异常类型及其修复措施在Java函数开发过程中,可能遇到各种异常,影响函数的正确执行。以下是常见的异常类型及其修复措施:1.NullPointerException描述:当访问一个还未初始化的对象时抛出。修复措施:确保在使用对象之前对其进行非空检查。示例代码:try{Stringname=null;System.out.println(name.length());}catch(NullPointerExceptione){

overflow 是 CSS 的一个属性,用于控制元素内容超出容器时的显示方式,可用值包括:visible:内容可见,溢出容器hidden:剪切溢出内容scroll:显示滚动条查看溢出内容auto:浏览器自动判断是否显示滚动条inherit:继承父元素的 overflow 属性

抖音作为全球知名的短视频平台,拥有庞大的用户群体和内容创造者。然而,随着平台规则的不断更新和完善,一些用户可能会遇到账号被封禁的情况。这引发了公众对于平台管理透明度和公正性的质疑。本文将探讨抖音账号封禁问题,以及用户在遇到账号被封后是否有申诉的途径。在抖音平台被封禁的原因可能有很多,包括但不限于涉及违法违规内容、违反平台规定、侵犯他人权益等。为了维护平台的秩序和用户的利益,抖音设置了一系列规则和审核机制。当一些用户违反规定时,他们的账号可能会被封禁。然而,有些用户可能会对封禁的理由产生质疑或不满
