当前位置: 代码网 > it编程>编程语言>Javascript > vue.config.js配置proxy代理产生404错误的原因及解决

vue.config.js配置proxy代理产生404错误的原因及解决

2024年07月02日 Javascript 我要评论
在使用vue做开发时,请求api接口时为了解决跨域问题,一般会设置proxy代理,但有时候会莫名其妙的出现404错误,这里总结一下vue设置proxy代理产生404错误的几种原因:原因1:没有注意vu

在使用vue做开发时,请求api接口时为了解决跨域问题,一般会设置proxy代理,

但有时候会莫名其妙的出现404错误,这里总结一下vue设置proxy代理产生404错误的几种原因:

原因1:没有注意vue proxy代理优先级的规则

vue proxy代理匹配的规则是按照配置的内容从上到下,顺序逐个匹配的

因此第一个被匹配到的规则生效以后, 后面就不会被匹配到

举个例子:

proxy: {
 
      "/api/": {
        target: "http://proxyaddr:port",
        changeorigin: true,
        pathrewrite: {
          "^/api": "",
        },
      },
 
       "/api2/": {
        target: "http://proxyaddr2:port",
        changeorigin: true,
        pathrewrite: {
          "^/api2": "",
        },
      },
 
 
}

按照上面的写法:

  • 如果有一个/api2的请求进来,会直接被第一条"/api"的规则匹配到
  • 而后面的"/api2"的规则就不会被匹配到,所以此时就会产生404错误

解决办法

把/api2的匹配规则放到/api的前面

注意点小结:

  • 对于有同名前缀的uri路径(比如/api和/apixxxx这样的)
  • 为了避免长uri路径被短uri规则匹配到,而后面的规则不生效
  • 必须把短uri路径的匹配规则放到文件的最后

原因2:pathrewrite路径重写配置错误

这个例子中pathwrite写错了:

  • 被重写的部分跟进来的url内容完全不同,没有被识别到
  • 这种情况也会发生路由匹配不到引发的404错误

所以,必须注意:

  • pathwrite的被重写的路径必须跟匹配规则定义的uri保持一致!
  • 否则就会报404错误!

总结

以上就是vue.config.js配置proxy代理发生404错误的两大原因。

这些仅为个人经验,希望能给大家一个参考,也希望大家多多支持代码网。

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com