vue解决跨域问题(Vue-CLI)

1. 创建vue.config.js文件;

打开项目,在vue项目的根目录下创建vue.config.js文件。


2.配置vue.config.js文件;

module.exports = {
    devServer: {
        proxy: {
            '/api': {                              //需要代理的接口
                target: 'http://39.98.***.211',    //目标服务器
                changeOrigin: true,                //是否跨域
                pathRewrite: { '^/api': 'api' },   //重写
            },
        },
    },
}

举一个栗子🌰:我需要访问的接口是:http://32.88.***.818/api/abb,123 ,"/api"是一个标识,告诉它只代理接口里面有 "/api" 这个字段的接口,我的目标服务器http://32.88.***.818,即target定义的,pathRewrite重写'^/api': '/api' 就是在代理是时候使用 /api 代理。


3.调用接口。

  • 第一种情况,重写值为自身(pathRewrite: { '^/api': 'api' })
this.axios.get('/api/abb').then((res)=>{
    console.log(res)
})
  • 第二种情况,重写值为空(pathRewrite: { '^/api': ' ' })

this.axios.get('/api/api/abb').then((res)=>{
    console.log(res)
})

注:此方法只适用于本地开发。如发布到生产环境接口与前端在不同域,需服务器配置代理。

  • 配置代理中 module.exports 是什么意思?

   module.exports 对象是由模块系统创建的。在我们自己写模块的时候,需要在模块最后写好模块接口,声明这个模块对外暴露什么内容,module.exports 提供了暴露接口的方法。

  • 配置代理中 devServer 是什么意思?

     浏览器如果需要开发某些特定功能,需要https浏览器才会给予功能权限, 则开发时我们需要在https环境 下面是配置一个webpack devServer的https环境。

  •  配置代理中 proxy 是什么意思

     proxy 也就是代理,可以帮助我们完成很多事情,例如对数据的处理,对构造函数的处理,对数据的验证,说白了,在目标对象之前架设一层“拦截”,外界对该对象的访问,都必须先通过这层拦截,因此提供了一种机制,可以对外界的访问进行过滤和改写。

  • 40
    点赞
  • 31
    收藏
    觉得还不错? 一键收藏
  • 28
    评论
评论 28
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值