最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

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

来源:动视网 责编:小采 时间:2020-11-27 22:02:37
文档

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

webpack配置proxyTable时pathRewrite无效的解决方法:本人webpack版本3.6,webpack-dev-server版本2.9.1,本人按照网上写的版本折腾两天都没通,无意间自己试通了,猜测网上大部分都是照本宣科,没有自己实践 webpack配置接口地址代理 在项目开发中,接口联调的时候一般都是同域名下,且不存在跨域的情况下进行
推荐度:
导读webpack配置proxyTable时pathRewrite无效的解决方法:本人webpack版本3.6,webpack-dev-server版本2.9.1,本人按照网上写的版本折腾两天都没通,无意间自己试通了,猜测网上大部分都是照本宣科,没有自己实践 webpack配置接口地址代理 在项目开发中,接口联调的时候一般都是同域名下,且不存在跨域的情况下进行


本人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/*',至于为什么,我表示也没有搞明白,不过确实调通了代理,希望对大家有帮助

文档

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

webpack配置proxyTable时pathRewrite无效的解决方法:本人webpack版本3.6,webpack-dev-server版本2.9.1,本人按照网上写的版本折腾两天都没通,无意间自己试通了,猜测网上大部分都是照本宣科,没有自己实践 webpack配置接口地址代理 在项目开发中,接口联调的时候一般都是同域名下,且不存在跨域的情况下进行
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top