webpack配置proxyTable时pathRewrite无效

 本人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

即:前端本地启动接口为:upload/201812141602000518.gif" alt="复制代码" style="margin: 0px; float: left; max-width: 650px; height: auto; border: none !important;" />

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': '/'         }       }     },   } 
                    
50000+
5万行代码练就真实本领
17年
创办于2008年老牌培训机构
1000+
合作企业
98%
就业率

联系我们

电话咨询

0532-85025005

扫码添加微信