vue-cli 3.0之跨域请求devServer proxy代理配置

醉酒当歌 提交于 2019-12-04 20:07:33

vue-cli 3.0之跨域请求devServer proxy代理配置

当我们的前端服务和后端服务不同源即协议不同端口不同域名不同时,就会出现跨域的问题。
通过配置devServer.proxy就可以解决跨域的问题。
基本配置:

// 将任何未知请求 (没有匹配到静态文件的请求) 代理到http://localhost:4000
module.exports = {
  devServer: {
    proxy: 'http://localhost:4000'
  }
}

详细配置:
dev-server.proxy使用功能强大的 http-proxy-middleware 软件包。
假如我们需要请求:http://common.dm.com/api/loginPost
但实际请求是:http://localhost:3000/api/loginPost
我们需要请求到 http://common.dm.com 下的接口就需要配置:

module.exports = {
    devServer: {
        proxy: {
            // 只有碰到/api的才会执行代理
            '/api': {
                target: 'http://common.dm.com', // 要访问的跨域的域名
                ws: true, // 是否启用websockets
                changeOrigin: true // 开启代理:在本地会创建一个虚拟服务端,然后发送请求的数据,并同时接收请求的数据,这样客户端端和服务端进行数据的交互就不会有跨域问题
            }
        }
    }
}

pathRewrite属性的用处:
如果我们要请求:http://common.dm.com/api/loginPost
但实际请求是:http://localhost:3000/mock/loginPost

module.exports = {
    devServer: {
        proxy: {
            '/mock': {
                target: 'http://common.dm.com',
                ws: true,
                changeOrigin: true,
                pathRewrite: {
                    '^/mock': '/api'
                }
            }
        }
    }
}
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!