前端本地开发中,代理配置是如何解决跨域的?

跨域(Cross-Origin)

这里再说一下跨域的概念吧。

在Web开发中,浏览器限制了从一个不同来源(协议、域名或者端口) 获取资源的访问。
当在一个页面中通过 Ajax 或者 JavaScript 访问其他域名下的资源时,就会产生跨域问题。

举些例子:

  • http://example.com | https://example.com 域名相同,但协议不同(http 和 https)
  • http://example.com | http://example.com:8080 域名相同,但端口号不同
  • http://example.com | http://test.example.com 主机名(子域)不同
  • https://example.com | https://anotherdomain.com 域名不同
  • file://localhost/index.html | http://example.com 文件协议和HTTP协议之间的跨域

开发代理

在开发过程中,我们可以通过代理相关的配置,来使得我们可以正常开发。

create-react-app

// setupProxy.js
const { createProxyMiddleware } = require('http-proxy-middleware');

module.exports = function(app) {
  app.use(
    '/api',
    createProxyMiddleware({
      target: 'http://api.example.com',
      changeOrigin: true,
    })
  );
};

vite

// vite.config.js

module.exports = {
  server: {
    proxy: {
      '/api': {
        target: 'http://api.example.com',
        changeOrigin: true,
        rewrite: path => path.replace(/^\/api/, ''),
      },
    },
  },
};

umi

// .umirc.js

export default {
  proxy: {
    "/api": {
      target: "http://api.example.com",
      changeOrigin: true,
      pathRewrite: { "^/api": "" },
    },
  },
};

原理

先说一下三个概念

  • 文章开头说的跨域的概念,是谁限制了资源访问?
  • cra、vite、umi都有开发服务器的概念,前端代码运行在了它们的开发服务器上
  • 实际上跨域请求,请求正常发送了,被请求的一方是也是正常返回了的,只是浏览器限制了资源访问。并不是说因为跨域了,连请求都没有发送。

那代理到底是如何解决跨域的?

  1. 我是运行在node端的开发服务器,我跑起来了,运行着前端代码
  2. 工程里有代理配置呀,看来我要拦截一下符合条件的请求了
  3. 来了一个请求:post("/api/getList");符合/api我要把他拦下来
  4. 他要代理到哪呢,我看看targerhttp://api.example.com,还需要rewrite/api删掉,那我实际的请求就是http://api.example.com/getList
  5. ok,我来发请求吧,我是node端服务器,不存在跨域问题。ok,拿到了返回结果。
  6. 我把结果给post("/api/getList")了。他请求的是http://localhost/api/getList,他不存在跨域问题。
  7. 结束

其实就是node端(服务器端)去请求拿到了response,然后把返回结果塞给了我们写的请求。

补充

另外只要返回的结果告诉浏览器,请求我的网址没关系,你别拦,我的内容给他就行。也不会产生跨域问题。
在这里插入图片描述
https://baike.baidu.com/里请求了https://miao.baidu.com/abdr。返回的内容(Response Header)告诉浏览器:允许https://baike.baidu.com/访问我(Access-Control-Allow-Origin),你不用拦。

参考视频

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值