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错误的两大原因。
这些仅为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
详解如何在Vue3使用<script lang=“ts“ setup>语法糖
本文主要介绍了在Vue3使用<script lang=“ts“ setup>语法糖,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2022-06-06
vue-router实现简单vue多页切换、嵌套路由、路由跳转的步骤和报错
最近学习到VUE路由这块,发现这块知识点有点多,好容易混乱,这篇文章主要介绍了vue-router实现简单vue多页切换、嵌套路由、路由跳转的步骤和报错的相关资料,需要的朋友可以参考下2024-05-05
vue-awesome-swiper 基于vue实现h5滑动翻页效果【推荐】
说到h5的翻页,很定第一时间想到的是swiper。但是我当时想到的却是,vue里边怎么用swiper。这篇文章主要介绍了vue-awesome-swiper - 基于vue实现h5滑动翻页效果 ,需要的朋友可以参考下2018-11-11
vue-cli5.0 webpack 采用 copy-webpack-plugin 打包复制文件的方法
今天就好好说说vue-cli5.0种使用copy-webpack-plugin插件该如何配置的问题。这里我们安装的 copy-webpack-plugin 的版本是 ^11.0.0,感兴趣的朋友一起看看吧2022-06-06


最新评论