webpack配置proxyTable时pathRewrite无效的解决方法


Posted in Javascript onDecember 13, 2018

本人webpack版本3.6,webpack-dev-server版本2.9.1,本人按照网上写的版本折腾两天都没通,无意间自己试通了,猜测网上大部分都是照本宣科,没有自己实践

webpack配置接口地址代理

在项目开发中,接口联调的时候一般都是同域名下,且不存在跨域的情况下进行接口联调,但是当我们在本地启动服务器后,比如本地开发服务下是 http://localhost:8080 这样的访问链接,但是我们的接口地址是  http://www.xxx.com/save/post 这样的,我们这样直接使用就会存在跨域的请求,导致接口请求不成功。

配置:

我们打开下面路径的文件

config/index.js

在其中的 dev 对象里面找到: proxyTable: {}

这里就是配置代理的地方,我们进行如下设置:

module.exports = {
 // ...
 dev: {
  // 代理配置表,在这里可以配置特定的请求代理到对应的API接口
  proxyTable: {
   '/api': {
    target: 'http://www.xxx.com', // 你接口的域名
    secure: false,   // 如果是https接口,需要配置这个参数为true
    changeOrigin: true,   // 如果接口跨域,需要进行这个参数配置为true
  
   }
  },
 }
}

接口地址原本是 /save/post ,但是为了匹配代理地址,在前面加一个  /api , 因此接口地址需要写成这样的即可生效  /api/save/post 。

即:前端本地启动接口为:http://localhost:8080/api/save/post,转发的代理接口为:http://www.xxx.com/api/save/post,其中的/api为匹配项。

/api 是本地路径和后端接口路径的匹配前缀,若后端接口给了/api这个前缀,可用上面的写法。

若后端前缀不统一,则可继续添加,写法如下:

module.exports = {
 // ...
 dev: {
  // 代理配置表,在这里可以配置特定的请求代理到对应的API接口
  proxyTable: {
   '/api': {
    target: 'http://www.xxx.com', // 你接口的域名
    secure: false,   // 如果是https接口,需要配置这个参数为true
    changeOrigin: true,   // 如果接口跨域,需要进行这个参数配置为true
  
   },
   '/api': {
    target: 'http://www.xxx.com', // 你接口的域名
    secure: false,   // 如果是https接口,需要配置这个参数为true
    changeOrigin: true,   // 如果接口跨域,需要进行这个参数配置为true
  
   }
  },
 }
}

那么还有一种情况,是后端的接口没有我们想要的匹配项(前缀)'/api',是直接的http://www.xxx.com/save/post,这样的接口,我们就要用到pathRewrite来重写地址,将本地路径上的带匹配前缀的路径:http://localhost:8080/api/save/post上的前缀'/api'转成 ‘ / '。以下第一种是网络上大部分推荐的,但是我亲测是无效的,估计他们多数用的上面的方法,没有实际使用下面的方法,LZ用以下第一种方法折腾了2天无果,后去看了webpack-dev-server的issue,无意义试通了接口,即下面第二种方法,当然也不排除第一种方法是我的版本问题而没有效果,所以如果大家试了第一种方法有效就当我的方法没说,如果无效,不妨试试我的第二种方法:

第一种方法(网上写的方法)

module.exports = {
 // ...
 dev: {
  // 代理配置表,在这里可以配置特定的请求代理到对应的API接口
  proxyTable: {
   '/api': {
    target: 'http://www.xxx.com', // 你接口的域名
    secure: false,   // 如果是https接口,需要配置这个参数为true
    changeOrigin: true,   // 如果接口跨域,需要进行这个参数配置为true
    pathRewrite: {
     '^/api': '/'
    }
   }
  },
 }
}

第二种方法(亲测有效的方法)

module.exports = {
 // ...
 dev: {
  // 代理配置表,在这里可以配置特定的请求代理到对应的API接口
  proxyTable: {
   '/api/*':{
    target: "http://XXX.XXX.com",
    changeOrigin: true,
    pathRewrite: {'/api':'/'}
   }
  },
 }
}

即将上面的匹配项从 ‘/api' 改成了 '/api/*',至于为什么,我表示也没有搞明白,不过确实调通了代理,希望对大家有帮助

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JavaScript简单实现网页回到顶部功能
Nov 12 Javascript
JS中如何设置readOnly的值
Dec 25 Javascript
jquery选择器大全 全面详解jquery选择器
Mar 06 Javascript
js中substring和substr的定义和用法
May 05 Javascript
javascript中的__defineGetter__和__defineSetter__介绍
Aug 15 Javascript
jQuery实现下拉框功能实例代码
May 06 Javascript
JQuery之proxy实现绑定代理方法
Aug 01 Javascript
使用JavaScriptCore实现OC和JS交互详解
Mar 28 Javascript
利用JS实现简单的瀑布流加载图片效果
Apr 22 Javascript
详解html-webpack-plugin用法全解
Jan 22 Javascript
解决vue中el-tab-pane切换的问题
Jul 19 Javascript
vue实现前端列表多条件筛选
Oct 26 Javascript
node.js学习笔记之koa框架和简单爬虫练习
Dec 13 #Javascript
浅谈vuex actions和mutation的异曲同工
Dec 13 #Javascript
webpack3里使用uglifyjs压缩js时打包报错的解决
Dec 13 #Javascript
javascript对HTML字符转义与反转义
Dec 13 #Javascript
Web安全之XSS攻击与防御小结
Dec 13 #Javascript
JavaScript实现邮箱后缀提示功能的示例代码
Dec 13 #Javascript
深入理解js A*寻路算法原理与具体实现过程
Dec 13 #Javascript
You might like
新闻分类录入、显示系统
2006/10/09 PHP
php实现文件下载简单示例(代码实现文件下载)
2014/03/10 PHP
thinkphp中的url跳转用法分析
2016/07/12 PHP
php基于websocket搭建简易聊天室实践
2016/10/24 PHP
关于PHP中字符串与多进制转换函数的实例代码
2016/11/03 PHP
解决Laravel自定义类引入和命名空间的问题
2019/10/15 PHP
PHP生成随机密码4种方法及性能对比
2020/12/11 PHP
wordpress之js库集合研究介绍
2007/08/17 Javascript
JavaScript 动态生成方法的例子
2009/07/22 Javascript
用JS提交参数创建form表单在FireFox中遇到的问题
2013/01/16 Javascript
各浏览器对document.getElementById等方法的实现差异解析
2013/12/05 Javascript
基于jquery实现等比缩放图片
2014/12/03 Javascript
jquery使用each方法遍历json格式数据实例
2015/05/18 Javascript
javascript中数组方法汇总
2015/07/07 Javascript
分享几种比较简单实用的JavaScript tabel切换
2015/12/31 Javascript
JavaScript中将数组进行合并的基本方法讲解
2016/03/07 Javascript
Bootstrap表单布局样式代码
2016/05/31 Javascript
React简单介绍
2017/05/24 Javascript
bootstrap日期插件daterangepicker使用详解
2017/10/19 Javascript
vux uploader 图片上传组件的安装使用方法
2018/05/15 Javascript
vue-cli3.0 环境变量与模式配置方法
2018/11/08 Javascript
Vue keepAlive 数据缓存工具实现返回上一个页面浏览的位置
2019/05/10 Javascript
判断js数据类型的函数实例详解
2019/05/23 Javascript
微信小程序跨页面传递data数据方法解析
2019/12/13 Javascript
python实现图书馆研习室自动预约功能
2018/04/27 Python
Python中三元表达式的几种写法介绍
2019/03/04 Python
用python给自己做一款小说阅读器过程详解
2019/07/11 Python
Python企业编码生成系统总体系统设计概述
2019/07/26 Python
Bose加拿大官方网站:美国知名音响品牌
2019/03/21 全球购物
Perfume’s Club德国官网:在线购买香水
2019/04/08 全球购物
英国顶级足球鞋的领先零售商:Lovell Soccer
2019/08/27 全球购物
介绍一下Java中的Class类
2015/04/10 面试题
2014世界杯球队球队口号
2014/06/05 职场文书
初中团支书竞选稿
2015/11/21 职场文书
python爬取某网站原图作为壁纸
2021/06/02 Python
浅谈Python数学建模之数据导入
2021/06/23 Python