vue使用proxyTable设置接口代理

本文介绍在本地环境中如何通过配置代理表解决跨域请求问题,详细解释了如何在config/index.js中设置代理,使得本地开发环境下的请求能够正确地代理到目标API接口。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在localhost环境下跑项目时,接口地址是 http://xxxx.com/save/index 这样的接口地址,我们这样直接使用会存在跨域的请求,导致接口请求不成功,我们进入 config/index.js 代码下如下配置即可。

dev: {
// 静态资源文件夹
assetsSubDirectory: ‘static’,
// 发布路径
assetsPublicPath: ‘/’,
// 代理配置表,在这里可以配置特定的请求代理到对应的API接口
// 例如将’localhost:8080/api/xxx’代理到’www.example.com/api/xxx’
// 使用方法:https://vuejs-templates.github.io/webpack/proxy.html
proxyTable: {
‘/api’: {
target: ‘http://xxxxxx.com’, // 接口的域名
// secure: false, // 如果是https接口,需要配置这个参数
changeOrigin: true, // 如果接口跨域,需要进行这个参数配置
pathRewrite: {
‘^/api’: ‘’
}
}
},
// 本地访问 http://localhost:8080
host: ‘localhost’, // can be overwritten by process.env.HOST
port: 8080, // can be overwritten by process.env.PORT, if port is in use, a free one will be determined

接口地址原本是 /save/index,但是为了匹配代理地址,在前面加一个 /api, 因此接口地址需要写成这样的即可生效 /api/save/index。

注意: ‘/api’ 为匹配项,target 为被请求的地址,因为在 ajax 的 url 中加了前缀 ‘/api’,而原本的接口是没有这个前缀的,所以需要通过 pathRewrite 来重写地址,将前缀 ‘/api’ 转为 ‘/’。如果本身的接口地址就有 ‘/api’ 这种通用前缀,就可以把 pathRewrite 删掉。

自己的理解:这个配置只是对本地环境的配置,和打包后的线上环境是没关系的,如果线上的前后端代码不在同一域名下,那就要通过其他方式来解决了,我们公司目前用的nginx代理

{
      //'^/api': '/api'   // 这种接口配置出来     http://XX.XX.XX.XX:8083/api/login
                    //'^/api': '/' 这种接口配置出来     http://XX.XX.XX.XX:8083/login
                    '^/api':'/'
                   }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值