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


    跨域(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,
        })
      );
    };
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12

    vite

    // vite.config.js
    
    module.exports = {
      server: {
        proxy: {
          '/api': {
            target: 'http://api.example.com',
            changeOrigin: true,
            rewrite: path => path.replace(/^\/api/, ''),
          },
        },
      },
    };
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13

    umi

    // .umirc.js
    
    export default {
      proxy: {
        "/api": {
          target: "http://api.example.com",
          changeOrigin: true,
          pathRewrite: { "^/api": "" },
        },
      },
    };
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    原理

    先说一下三个概念

    • 文章开头说的跨域的概念,是谁限制了资源访问?
    • 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),你不用拦。

    参考视频

  • 相关阅读:
    Linux开发板安装Ubuntu标准桌面环境(或其他桌面环境)
    IOS XCode Objectc SHA256加密
    spring boot 2.7 -> 3.0升级指南
    react学习笔记3--数据双向绑定,组件通信
    Linux内核--链表结构
    React 入门:组件化编码流程(一)拆分组件
    GPT的全面历史和演变:从GPT-1到GPT-4
    【Golang】简记操作:Centos安装、卸载、升级Golang运行环境
    【算法教程】排列与组合的实现
    信息学奥赛一本通2061:【例1.2】梯形面积
  • 原文地址:https://blog.csdn.net/BWater_monster/article/details/133882993