解决 vue + go-zero 出现的跨域问题

解决 vue + go-zero 出现的跨域问题,第1张

环境:

前端: vue-element-admin

服务端: go-zero

问题:由于前端地址端口和服务端端口不一样导致请求跨域

先放结果:

main()中修改

func main() {
	flag.Parse()

	var c config.Config
	conf.MustLoad(*configFile, &c)

	ctx := svc.NewServiceContext(c)

	server := rest.MustNewServer(c.RestConf, rest.WithCustomCors(nil, notAllowedFn, "http://localhost:9528")) // 客户端地址
	defer server.Stop()

	handler.RegisterHandlers(server, ctx)

	fmt.Printf("Starting server at %s:%d...\n", c.Host, c.Port)
	server.Start()
}

func notAllowedFn(w http.ResponseWriter) {
	w.Header().Add("Access-Control-Allow-Headers", "x-token")
}

解决过程:

在github中找到作者回答

现在跨域可以这么写,从 v1.2.3 开始

srv := rest.MustNewServer(c, rest.WithCors())

如果单个域名可以这么写:

srv := rest.MustNewServer(c, rest.WithCors("http://example.com"))

 改好之后在前端依旧报错:

Request header field x-token is not allowed by Access-Control-Allow-Headers in preflight response.

需要在Access-Control-Allow-Headers中添加“x-token”

如果是v1.2.3,我的办法是直接修改源代码 rest/internal/cors/handlers.go 

allowHeadersVal  = "Content-Type, Origin, X-CSRF-Token, Authorization, AccessToken, Token, Range"

在后添加x-token

在1.2.4版本之后作者添加了WithCustomCors方法可以自定义response

做法如上。

原理可参考 跨域资源共享(Cross-origin resource sharing)CORS_Coder-CSDN博客

在找到WithCustomCors之前还尝试过在vue中使用代理

在 vue.config.js 中的 devServer 添加

    proxy: {
      '/api': {
        target: 'http://127.0.0.1:8888',
        changeOrigin: true,
        pathRewrite: {
          '^/api': ''
      }
      },
    },

本地会虚拟化一个服务器帮你把这个请求代发给后台,从而避免跨域问题。

这个方法一直报503,未找到原因

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/langs/994428.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-21
下一篇 2022-05-21

发表评论

登录后才能评论

评论列表(0条)

保存