博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
webpack配置proxyTable时pathRewrite无效的解决方法
阅读量:6324 次
发布时间:2019-06-22

本文共 2123 字,大约阅读时间需要 7 分钟。

webpack配置接口地址代理

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

配置:

我们打开下面路径的文件

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 。

即:前端本地启动接口为::8080/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``},`欢迎加入全栈开发交流划水交流圈:582735936面向划水1-3年前端人员帮助突破划水瓶颈,提升思维能力`'/api'``: {``target:` `'[http://www.xxx.com](http://www.xxx.com/)'``, // 你接口的域名``secure:` `false``,` `// 如果是https接口,需要配置这个参数为true``changeOrigin:` `true``,` `// 如果接口跨域,需要进行这个参数配置为true``}``},``}``}`

那么还有一种情况,是后端的接口没有我们想要的匹配项(前缀)'/api',是直接的,这样的接口,我们就要用到pathRewrite来重写地址,将本地路径上的带匹配前缀的路径::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'``:``'/'``}``}``},``}``}`

转载地址:http://bvmaa.baihongyu.com/

你可能感兴趣的文章
什么是.Net, IL, CLI, BCL, FCL, CTS, CLS, CLR, JIT
查看>>
Atlas Control ToolKit 发布
查看>>
Dundas 系列
查看>>
Windows的命令行查看,修改,删除,添加环境变量
查看>>
iOS 图文混排
查看>>
GC是什么? 为什么要有GC?
查看>>
JQuery EasyUi之界面设计——母版页以及Ajax的通用处理(三)
查看>>
童年记忆
查看>>
Selenium Python bindings 文档一
查看>>
directX的16位和24位的色彩模式
查看>>
WINDOWS 8
查看>>
ASP.NET MVC涉及到的5个同步与异步,你是否傻傻分不清楚?[下篇]
查看>>
spring(10)
查看>>
Ubuntu 12.04 LTS 及ubuntu14.10 -- NFS安装
查看>>
hdu 5063 Operation the Sequence(Bestcoder Round #13)
查看>>
django orm多条件查询及except处理不存在记录的样码
查看>>
8.3折抢购最欢迎的Mac清理工具CleanMyMac3
查看>>
第十五章 springboot + pojo默认值设置
查看>>
linux grep命令
查看>>
Button MouseEvent颜色变化
查看>>