【vue cli2 & 3】 本地代理解决跨域问题

一、vue-cli2

在config/index.js中修改proxyTable:

module.exports = {
  dev: {

    // Paths
    assetsSubDirectory: 'static',
    assetsPublicPath: '/',
    // proxyTable: {},//原来为空
    proxyTable: {
      //这里自定义
      '/api': { //自己命名
        target: "https://xxx.com", //要代理的网址
        changeOrigin: true, //是否跨域
        pathRewrite: {
          '^/api': "https://xxx.com" //重写路径
        }
      },
    },

    .....
  },

  .....
}

在定义接口的文件中(一般是src/request/api.js):

const url = '/api'; //上一步自己起的名字


//  接口定义
export const register = data => {
  return request.post(url + "/register", data);
};

二、vue-cli3

修改根目录下的vue.config.js:

module.exports = {
  
  .....

  // webpack-dev-server 相关配置
  devServer: {
    host: '0.0.0.0',
    port: '80',
    // 自动打开浏览器
    open: true,
    proxy: {
      '/':{  //自命名
        changeOrigin: true,
        target:'https://xxx.com/', //要代理的域名
      }
    },

    ....
  },

  ....
}

修改src/utils/request.js:

// 创建axios实例
const service = axios.create({
  baseURL: '/', //上面的自命名
  // 超时
  timeout: 20000,
})

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值