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

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'
                }
            }
        }
    }
}
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在使用Vue-cli进行开发时,我们常常会遇到的问题。为了解决这个问题,我们可以使用vue.config.js文件进行代理设置。 首先,打开项目根目录下的vue.config.js文件。 其次,我们需要在该文件中添加一个devServer选项,来进行代理配置。具体代码如下: ``` module.exports = { devServer: { proxy: { '/api': { target: 'http://example.com', // 需要名 changeOrigin: true, // 是否进行 pathRewrite: { '^/api': '' // 将/api替换为空字符串 } } } } } ``` 其中,target指定了需要请求名。changeOrigin设置为true表示开启。pathRewrite用于重写请求地址,将/api替换为空字符串。 最后,保存文件并重新运行项目。此时,我们就成功地设置了代理。 然而,有时候我们可能会遇到404错误。这通常是因为代理的地址不正确,或者目标服务器无法处理正确的路由地址。 我们需要确保target的值和实际需要请求名一致。另外,需要确保pathRewrite中的替换规则正确。 如果以上操作仍然无法解决问题,可以参考目标服务器的接口文档,确认请求地址是否正确。同时,可以使用开发工具的网络面板查看请求的详细信息,以便进行进一步的排查。 总结:使用vue-cli进行代理时,可以通过配置vue.config.js文件来解决问题。如果出现404错误,需要检查配置是否正确,并确认目标服务器是否能正确处理请求

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值