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

webpack配置接口地址代理css

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

配置:前端

咱们打开下面路径的文件vue

config/index.jsnode

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

这里就是配置代理的地方,咱们进行以下设置:web

`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,转发的代理接口为:www.xxx.com/api/save/po…,其中的/api为匹配项。后端

/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',是直接的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,快速升职加薪,走上人生巅峰。


相关文章
相关标签/搜索