在vue中使用proxy解决跨域问题(转载记录)

在vue中使用proxy解决跨域问题(转载记录)

在vue中使用proxy进行跨域的原理是:将域名发送给本地的服务器(启动vue项目的服务,loclahost:8080),再由本地的服务器去请求真正的服务器。

1.在proxy中设置要访问的地址,并重写/api为空的字符串,因为我们真正请求的地址是没有带/api,这个重写很重要!!!

在这里插入图片描述

2.在创建axios实例的时候将baseURL设置为/api ,这时候我们的跨域就已经完成了。

在这里插入图片描述

3. 假如请求的真正地址为:http://121.121.67.254:8185/core/getdata/userInfo,但我们在浏览器上会看到是这样的: http://localhost:8080/api/core/getData/userInfo ,多了个/api,但并不影响我们请求数据。

在这里插入图片描述
vue.config.js

module.exports = {
    // baseUrl: process.env.NODE_ENV === 'production' ? '/' : '/',
    assetsDir: 'static',
    productionSourceMap: false,
    devServer: {
        host:'127.0.0.1',
        // host:'192.168.0.89',
        port:'8080',
        proxy: {
            '/pro':{
                target:'http://192.168.0.182',//这里后台地址;填写真实的后台接口
                ws: true,
                changeOrigin:true,//允许跨域41
                pathRewrite:{
                    '^/pro':''
                }
            }
        }, // 设置代理
        headers: {
          'Access-Control-Allow-Origin': '*',
        },
        before: app => {}
    },
    // 第三方插件配置
    pluginOptions: {
        //...
    },
    lintOnSave: false
}
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值