vue解决跨域拦截proxy做代理服务器详解

webpack配置接口地址代理

我们打开下面路径的文件

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' 转成 ‘ / ’。
以下第一种是网络上大部分推荐的,但是我亲测是无效的,
估计他们多数用的上面的方法,没有实际使用下面的方法,
理解用以下第一种方法折腾了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/api",
changeOrigin: true,
pathRewrite: {'/api':'/'}
}
},
}
}
  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue代理服务器proxy是一个非常有用的功能,它可以用于将前端请求转发到后端接口,解决跨域问题。 首先,在Vue项目的根目录中找到vue.config.js文件,如果没有则手动创建一个。在vue.config.js文件中,我们可以通过配置proxy选项来设置代理服务器。 具体的proxy配置如下: ```javascript module.exports = { devServer: { proxy: { '/api': { target: 'http://localhost:8080', // 这里配置你想要请求的后端接口地址,可以是本地地址也可以是远程地址 changeOrigin: true, // 是否跨域 pathRewrite: { '^/api': '' // 将路径中的'/api'替换为空字符串 } } } } } ``` 以上代码表示将以'/api'开头的请求转发到target指定的后端地址。例如,前端请求/api/user会被转发到http://localhost:8080/user。 除了target之外,proxy还支持其他一些配置选项,比如changeOrigin和pathRewrite。 changeOrigin用于控制请求头中的host字段,如果设置为true,则请求头中的host字段会被设置为target的hostname;反之,请求头中的host字段保持不变。 pathRewrite用于重写请求路径,比如上述代码中的'^/api': ''表示将请求路径中的'/api'替换为空字符串。这样一来,前端请求/api/user经过代理服务器后,会被重写为/user发送给后端。 综上所述,Vue代理服务器proxy配置非常简单,只要按照上述格式在vue.config.js文件中进行配置即可。这样一来,前端就可以轻松地与后端进行交互,解决跨域问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值