通过设置代理解决Vue中的跨域问题

1.问题:

在vue中,在使用Axios获取数据时,有时会出现数据无法访问的情形(即跨域问题),如例1所示:

例1:在本地使用 Axios 来获取豆瓣上的数据

this.$axios({
      method: 'get',                                  //以 get 方式获取数据
      url: 'http://api.douban.com/v2/movie/top250'    //此处为豆瓣上的数据
    }).then(res => {
      console.log(res)                                //成功则返回请求的结果
    }).catch(err => {
      console.log(err)                                //失败则返回错误信息
    })

此时运行项目,在控制台中会得到如下提示信息:即是存在 跨域 问题

2.解决方法:

打开vue项目文件夹下的build目录,打开webpack.dev.conf.js:

选中 proxy 选项 ( 大概在第41行的位置 ),然后再打开 config/index.js 文件

在 proxyTable: { } 中设置跨域请求即可

第一步:设置proxyTable:

proxyTable: {
        '/douban_api':{       
            target: 'http://api.douban.com',
            pathRewrite: {
                '^/douban_api': ''
            },
            changeOrigin: true
        }
    },

第二步:在main.js中进行下一步的设置:

Vue.prototype.HOST = '/douban_api'

第三步:更改组件中数据的请求参数:

    let url = this.HOST + '/v2/movie/top250'        //进行地址的拼接
    this.$axios({
      method: 'get',
      url: url
    }).then(res => {
      console.log(res)
    }).catch(err => {
      console.log(err)
    })

第四步:打开浏览器,在控制台即可看到正确的输出结果

此时跨域问题成功解决

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值