为什么 cors 错误没有得到解决?
golang 中允许使用 cors,代码如下
func register() *echo.echo { e := echo.new() e.get("/swagger/*", echoswagger.wraphandler) // swagger 등록 validator.registervalidator(e) // 유효성검사 등록 e.use(middleware.cors()) // cors 등록 ...... package middleware import ( "github.com/labstack/echo/v4" "github.com/labstack/echo/v4/middleware" ) func cors() echo.middlewarefunc { return middleware.corswithconfig(middleware.corsconfig{ alloworigins: []string{"http://localhost:3000"}, allowmethods: []string{echo.get, echo.put, echo.post, echo.delete}, allowheaders: []string{echo.headerorigin, echo.headercontenttype, echo.headeraccept}, exposeheaders: []string{echo.headercontentlength}, }) }
但是,即使我在react项目中从(localhost:3000)发送请求,cors错误也不会停止。
func (serverInfo *ServerInfo) ServerStart() { var databaseSet database.DatabaseInterface = &mysql.MysqlInfo{} // Database databaseSet.InitDatabase() // 데이터베이스를 초기화합니다 hosts := map[string]*Host{} // Hosts // API hosts[fmt.Sprintf("%v.%v:%v", "api.v1", os.Getenv(envkey.SERVER_URL), os.Getenv(envkey.PORT))] = &Host{apiV1Route.Register()} // Server e := echo.New() e.Use(middleware.Logger()) // 로거등록 e.Any("/*", func(c echo.Context) (err error) { req := c.Request() res := c.Response() host := hosts[req.Host] if host == nil { err = echo.ErrNotFound } else { host.Echo.ServeHTTP(res, req) } return }) // e.Logger.Fatal(e.StartTLS(fmt.Sprintf(":%v", os.Getenv(envkey.PORT)), "housewhale.com+3.pem", "housewhale.com+3-key.pem")) e.Logger.Fatal(e.Start(fmt.Sprintf(":%v", os.Getenv(envkey.PORT)))) }
这个问题我已经困扰了好几天了,如何解决?我已经尝试了在手册或谷歌中找到的所有内容,但 cors 错误并没有消失。
正确答案
有一个错误,没有附加错误,我附加了如下错误,当时问题就解决了。
access to fetch at 'https://api.v1.localhsot:8081/auth/retoken' from origin 'http://localhost:3000' has been blocked by cors policy: response to preflight request doesn't pass access control check: no 'access-control-allow-origin' header is present on the requested resource. if an opaque response serves your needs, set the request's mode to 'no-cors' to fetch the resource with cors disabled.
服务器端未正确允许cors,请配置服务器端以匹配请求
例如,如果客户端向标头发送授权数据,则服务器也允许在标头中进行授权。像这样设置必要的请求
package middleware import ( "github.com/labstack/echo/v4" "github.com/labstack/echo/v4/middleware" ) func Cors() echo.MiddlewareFunc { return middleware.CORSWithConfig(middleware.CORSConfig{ AllowOrigins: []string{"http://localhost:3000"}, AllowMethods: []string{echo.GET, echo.PUT, echo.POST, echo.DELETE}, AllowHeaders: []string{echo.HeaderOrigin, echo.HeaderContentType, echo.HeaderAccept, echo.HeaderAuthorization}, ExposeHeaders: []string{echo.HeaderContentLength, echo.HeaderSetCookie}, AllowCredentials: true, // Add this line to allow credentials }) }
以上是为什么 cors 错误没有得到解决?的详细内容。更多信息请关注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)

本文解释了GO的软件包导入机制:命名imports(例如导入“ fmt”)和空白导入(例如导入_ fmt; fmt;)。 命名导入使包装内容可访问,而空白导入仅执行t

本文解释了Beego的NewFlash()函数,用于Web应用程序中的页间数据传输。 它专注于使用newflash()在控制器之间显示临时消息(成功,错误,警告),并利用会话机制。 Lima

本文详细介绍了MySQL查询结果的有效转换为GO结构切片。 它强调使用数据库/SQL的扫描方法来最佳性能,避免手动解析。 使用DB标签和Robus的结构现场映射的最佳实践

本文演示了创建模拟和存根进行单元测试。 它强调使用接口,提供模拟实现的示例,并讨论最佳实践,例如保持模拟集中并使用断言库。 文章

本文探讨了GO的仿制药自定义类型约束。 它详细介绍了界面如何定义通用功能的最低类型要求,从而改善了类型的安全性和代码可重复使用性。 本文还讨论了局限性和最佳实践

本文详细介绍了在GO中详细介绍有效的文件,将OS.WriteFile(适用于小文件)与OS.openfile和缓冲写入(最佳大型文件)进行比较。 它强调了使用延迟并检查特定错误的可靠错误处理。

本文使用跟踪工具探讨了GO应用程序执行流。 它讨论了手册和自动仪器技术,比较诸如Jaeger,Zipkin和Opentelemetry之类的工具,并突出显示有效的数据可视化
