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


    跨域(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),你不用拦。

    参考视频

  • 相关阅读:
    137. 只出现一次的数字 II
    FPGA 安装Quartus 13.1无法生成.sof文件
    Linux Centos/Debian NFS服务器查询搭建与配置
    获取小程序页面路径完整流程
    [附源码]java毕业设计智能超市导购系统
    2014华为Java笔试题+数据库题
    DFS 模板:843. n-皇后问题
    中值滤波器 median filter
    JAVA面试题——创建线程的三种方式
    场景分类任务可用数据集(部分)
  • 原文地址:https://blog.csdn.net/BWater_monster/article/details/133882993