umi 如何使用 proxy 代理解决 开发环境跨域 问题

跨域是什么

由于浏览器的同源策略限制,当一个请求 URL 的协议、域名、端口和当前页面 URL 任意一个不一致时都会出现跨域错误。

eg:
node run了一个http://localhost:8080 的服务,在这个服务器下访问的网页也默认在 http://localhost:8080 这个域下面;

假设服务端所在的域是http://example.com
这样通过ajax发送请求的话;

由客户端直接传过去的就是一个域名为 http://localhost:8080 的请求;
而服务端所在的域是 http://example.com;

域名不同,请求失败,出现跨域错误

解决跨域可以从两个方面着手

  1. 客户端
  2. 服务端

接下来介绍如何在 umi 中使用 proxy 代理处理跨域问题

代理解决跨域的原理

使用代理解决跨域的原理

在客户端和服务端之间加了一层中间层
中间层的作用:将不同的域名转换为相同的域名

在这里插入图片描述

  1. 客户端发送请求,先经过中间层的处理,将域名 http://localhost:8080 转换为 http://example.com
  2. 利用转换后的域名发送请求到server
  3. 服务端接收到请求的域名 http://example.com,相应经过中间层的处理,将域名进行转换,发送响应数据给客户端
  4. client 收到和自己相同的域名,继续下一步操作

umi使用proxy代理解决跨域

config.js配置文件里设置

proxy: {
  "/ci": { // 标识需要进行转换的请求的url
   "target": "http://example.com", // 服务端域名
   "changeOrigin": true, // 允许域名进行转换
   "pathRewrite": { "^/ci": ''}  // 将请求url里的ci去掉
  }
}

发送请求时需要将请求的url设置为 http://localhost:8080/ci/xx/xx,代理才会对这条请求的域名进行替换。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值