开发环境 vue-cli3 配置跨域

参考资料:

vue-cli3的devServer

webpack的dev-server配置

http-proxy-middleware

vue-cli 3.0之跨域请求devServer代理配置    // 这个讲得很清楚啦

 

建议去了解webpack和http-proxy-middleware感觉会比较清楚了

在vue.config.js文件(如果没有则创建)中配置:

module.exports = {
  devServer: {
    proxy: {
      '/v1': {
        target: 'http://192.168.1.33:9888', // 目标地址
        changeOrigin: true, //是否跨域
        ws: true,
        //重写路径  需要设置重写的话,要在后面的调用接口前加上/v1 来代替target
        pathRewrite:{
          // '^/v1': '',
        }
      // 可配置多个,如果路径有多个的话
      // '/v2': {
      //  target: 'http://192.168.1.33:9888', // 目标地址
      //  changeOrigin: true, //是否跨域
      //  ws: true,
        //重写路径  需要设置重写的话,要在后面的调用接口前加上/v2 来代替target
      //  pathRewrite:{
          // '^/v2': '',
      //  }
      }
    }
  }
}

如果项目用的是axios,则在axios中配置,只要将baseURL配置为空字符串''

axios.create({ baseURL:'' })

如果axios的baseURL配置为'/v1', 那么需要在proxy中重写路径, 否则不能跨域

pathRewrite:{
  '^/v1': '',
}

如果想要代理所有路径,那么可以在proxy中配置(将'/v1'改为'/):

proxy: {
  '/': { // '/'匹配所有路径,所有请求都会被代理
    target: 'http://192.168.1.33:9888',
    changeOrigin: true,
    ws: true
  }
}

这样子就解决了跨域啦

 

PS: 这是其中一种不需要后台配合的解决跨域的方式,附上跨域解决方案链接,挺全的了:

前端常见跨域解决方案(全)

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值