位置: IT常识 - 正文

vue.config.js 中 devServer.proxy 配置说明,以及配置正确不生效问题

发布时间:2024-01-08
vue.config.js 中 devServer.proxy 配置说明,以及配置正确不生效问题 文章目录proxy 配置确认、解析原因 一原因二注意详解请求路径必须带有标识!!!pathRewritechangeOriginproxy 配置确认、解析devServer: { https: true, // 开启https模式 // 配置服务器代理 proxy: { '/api': { // 匹配访问路径中含有 '/api' 的路径 target: 'http://localhost:3000/', // 测试地址、目标地址 changeOrigin: true, ws: true, // 是否开启 webSocket 代理 pathRewrite: { // 请求路径重写 '^/api': '', //重写请求路径 }, } } },原因 一

推荐整理分享vue.config.js 中 devServer.proxy 配置说明,以及配置正确不生效问题,希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

百度最多的解释

配置写错了 (解决:复制粘贴上面的实例下去改)路径没有匹配上 (解决:看本文的详解部分)原因二

这个原因得注意一下

方式是给我们开发环境用的 ,其次是我们的请求要被开发服务器接收到,且不能匹配到请求,然后我们的请求就会被代理到配置的URL。注释掉,或者改为本地路径,否则代理不会生效

比如说我之前的全局 http.js 配置文件是这样写的

const http = axios.create({ baseURL: 'http://localhost:3000/',})

所以不论是 生产 还是 开发 环境下,我的请求都会发送给我们配置的baseURL,而不会走我们的代理!!!。

所以我们得修改一下配置,使我们的生产路径在生产环境下才生效let baseURL = "/";if (process.env.NODE_ENV === 'production') { baseURL = 'http://localhost:3000/';}const http = axios.create({ baseURL,})

这样在开发环境下,我们的 baseURL = "/", 代理就可以生效了。

注意还有一点就是,即使我们的代理生效了,但是在浏览器请求头中展示的也不是配置的代理地址;所以测的时候得多问问后端请求过去没有,或者自己node搭个简易的服务器看看成没成功;不要一根筋的死盯浏览器的请求头地址。详解请求路径必须带有标识!!!proxy: { '/api': { ... } }

用代理首先你得有一个标识,表明你的这个连接要使用代理;

vue.config.js 中 devServer.proxy 配置说明,以及配置正确不生效问题

不然的话 html css js 这些静态资源都跑去代理。

/api 就是告诉 node ,我接口用 /api 开头的才使用代理,所以接口都写成 /api/xx/xx

出现问题: 请求路径没有 /api ,使用 pathRewrite 解决

pathRewritepathRewrite: { // 请求路径重写 '^/api': '', //重写请求路径 },

pathRewrite的key值 ^/api 就是一个正则表达式。

pathRewrite的value值 为替换后的路径。

这里的话就是将匹配成功的地址当做一个字符串,然后执行 js 的 replace 方法,将执行成功的最终结果作为最后的请求路径。

比如:我们有一个请求 axios.get("/api/aa/bb/cc") ;根据我们这里配置的 proxy, 带有 /api 的请求路径就需要进行代理,且 /api/aa/bb/cc 路径中含有 /api ,所以该请求就需要代理。将路径当做字符串执行, "/api/aa/bb/cc".replace(/^\/api/, "")执行结果: /aa/bb/cc最终的请求路径变成了 http://localhost:3000/aa/bb/cc 不含/api;而 axios.get("/ee/ff/dd") 这个请求就不会进行代理,因为匹配不上我们预设的规则 (请求路径没有 /api)最终的请求路径变成了 http://localhost:3000/ee/ff/dd, 和原路径一致;又比如说我们的配置为pathRewrite: { // 请求路径重写 '^/api': '/rewrite', //重写请求路径 }那么我们的请求 axios.get("/api/aa/bb/cc") ;会执行 "/api/aa/bb/cc".replace(/^\/api/, "/rewrite");最终的请求路径变成了 http:/rewrite/localhost:3000//aa/bb/cc;将 /rewrite 替换了开头的/api。changeOrigin

假设,如果你的前端服务器是 http://localhost:3000,后端是 http://localhost:8082。

那么后端通过 request.getHeader(“Host”) 获取依旧是 http://localhost:3000。

如果你设置了 changeOrigin: true,那么后端通过 request.getHeader(“Host”) 获取才是 http://localhost:8082。代理服务器此时会根据请求的 target 地址修改 Host。

点赞、收藏、投硬币,可爱女友不漏气!

本文链接地址:https://www.jiuchutong.com/zhishi/289726.html 转载请保留说明!

上一篇:雷尼尔山透镜状云的延时视频,华盛顿 (© Delrious/Shutterstock)(雷尼尔山位于美国西北部)

下一篇:将yolov5中的PANet层改为BiFPN(yolov5输出result)

  • 投资管理公司成立的条件
  • 金蝶迷你版年结怎么操作
  • 三供一业移交内容
  • 建筑行业一般纳税人增值税税率是多少
  • 减免的城建税怎么计算
  • 一张发票开不足一台设备的金额怎么办
  • 完全成本法例子
  • 个体工商户转让流程
  • 企业所得税的常设机构
  • 损失补偿原则的限制条件有
  • 公司分立是不是法人
  • 哪些进项税额不允许从销项税额中抵扣?
  • 个人所得税生产经营所得税率表2023
  • 宣传资料设计制作
  • 企业偷税漏税行为诉讼有效期限
  • 金税盘全额抵扣分录怎么做
  • 转登记日下期指的是什么
  • 工程施工科目核算
  • 应交增值税为负数代表什么
  • 营改增后的劳务费怎么开
  • 打英文字母突然没声音了
  • 应用程序出现异常怎么办
  • 成本加成定价法包括()
  • 固定资产进项税额怎么做账
  • 销售预付款会计分录
  • 如何解决连接宽带的方法
  • 情人节海报怎么画简单
  • macos big sur最新版本
  • 企业因政策性原因发生的巨额经营亏损
  • 固定资产如何做账务处理
  • 公司股东变更要交税吗可以将股东变更吗
  • PHP:mcrypt_get_iv_size()的用法_Mcrypt函数
  • 如何使用vue
  • yolov5目标检测代码
  • 人力资源企业税收风险
  • 累计折旧大白话
  • 印花税需要扣除负数发票吗
  • 银行存款利息的会计科目
  • 出纳对现金的收付应该怎么做
  • vue 鼠标移入移出(hover)切换显示图片问题
  • 不动产简易征收增值税发票 可以抵扣
  • 个人所得税是可以全部退回吗
  • 个体工商户未年报 经营异常罚款
  • 代扣代缴附加税减免政策文件
  • 公司地址的变更需要哪些资料和手续
  • 公司一般户的钱怎么拿出来
  • 公司法规定股权转让需要满足什么条件
  • 把办公场所转租合法吗
  • 小规模季度没超过45万怎么纳税增值税
  • 企业内账怎么做
  • 公司计提减值好吗
  • 房产预售什么时候开始
  • 数据库时区与url连接设置的时区
  • sqlserver 优化配置
  • win7怎么把桌面图标显示出来
  • kvm虚拟机是什么
  • Linux系统中配置网络包含( )方法
  • bd是什么文件
  • culauncherexe是什么进程
  • linux创建个人主页
  • mac的替换在哪里
  • linux怎么开启root权限
  • linux怎么下载安装腾讯Tim?
  • ie8-ie11浏览器
  • js前端导出word
  • 微信小程序实现微信支付
  • unity游戏人物选择
  • opengl渲染流程图
  • js如何引用
  • formatter参数
  • 详细解读了
  • node.js redis
  • shell读取文本
  • jqueryui easyui
  • 使用简单工厂模式的好处
  • jquery教程
  • javascript面向对象编程指南
  • python程序解读举例
  • 增值税税负偏低的风险点
  • 镇江市物业管理协会
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号