pathrewrite不生效_webpack配置proxyTable时pathRewrite无效的解决方法

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

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](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](http://www.xxx.com/)'``, // 你接口的域名`

`secure:` `false``,` `// 如果是https接口,需要配置这个参数为true`

`changeOrigin:` `true``,` `// 如果接口跨域,需要进行这个参数配置为true`

`},`

`'/api'``: {`

`target:` `'[http://www.xxx.com](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](http://www.xxx.com/)'``, // 你接口的域名`

`secure:` `false``,` `// 如果是https接口,需要配置这个参数为true`

`changeOrigin:` `true``,` `// 如果接口跨域,需要进行这个参数配置为true`

`pathRewrite: {`

`'^/api'``:` `'/'`

`}`

`}`

`},`

`}`

`}`

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

`module.exports = {`

`// ...`

`dev: {`

`// 代理配置表,在这里可以配置特定的请求代理到对应的API接口`

`proxyTable: {`

`'/api/*'``:{`

`target:` `"[http://XXX.XXX.com](http://xxx.xxx.com/)"``,`

`changeOrigin:` `true``,`

`pathRewrite: {``'/api'``:``'/'``}`

`}`

`},`

`}`

`}`

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

本次给大家推荐一个交流圈,里面概括移动应用网站开发,css,html,webpack,vue node angular以及面试资源等。

对web开发技术感兴趣的同学,欢迎加入:582735936,不管你是小白还是大牛我都欢迎,还有大牛整理的一套高效率学习路线和教程与您免费分享,同时每天更新视频资料。

最后,祝大家早日学有所成,拿到满意offer,快速升职加薪,走上人生巅峰。

本站文章为3672js教程网友分享投稿,版权归原作者,欢迎任何形式的转载,但请务必注明出处。同时文章内容如有侵犯了您的权益,请联系我们处理。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值