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

在使用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
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值