详解Vite 配置中的代理功能

在前端开发过程中,你可能经常会遇到一个头疼的问题:当你在本地启动的前端项目中调用后端接口时,浏览器控制台会报出类似 “Access to fetch at ‘http://xxx’ from origin ‘http://localhost:3000’ has been blocked by CORS policy” 的错误。这就是跨域问题,而 Vite 的代理功能正是解决开发阶段跨域问题的有效方案。

让我们从一段常见的 vite.config.ts 配置代码说起,看看其中的代理设置到底是如何工作的。
在 Vite 的配置文件中,server 选项用于配置开发服务器的行为,其中的 proxy 属性就是专门用来设置代理规则的。比如这样的配置:

server: {host: "0.0.0.0", // 默认为localhostport: 7001, // 端口号open: false, // 是否自动打开浏览器proxy: {// 第三方服务器的代理配置'/dev-api/PileManager': {target: 'http://personalpile.admin.usteu.com/',changeOrigin: true,rewrite: (path) => path.replace(/^\/dev-api/, '')},// 本地后端服务的代理配置"/dev-api": {target: "http://localhost:8050/",changeOrigin: true,rewrite: path => path.replace(new RegExp('^' + env.VITE_APP_BASE_API), '/api')}},
}

首先我们要理解,为什么需要代理。当你的前端项目运行在http://localhost:7001(由 port 指定),而后端接口部署在另一个域名或端口(比如http://localhost:8050)时,由于浏览器的同源策略限制,直接请求会被拦截。代理的作用就是让前端请求先发送到本地的 Vite 开发服务器,再由 Vite 服务器转发到目标后端服务器,这样就避开了浏览器的跨域限制。

我们来看 proxy 对象中的具体配置。这里定义了两组代理规则,每组规则都是一个键值对。键表示需要被代理的请求路径前缀,而值则是该前缀对应的代理配置。

先看第一个代理规则’/dev-api/PileManager’。当你的代码中发起类似fetch(‘/dev-api/PileManager/some/path’)的请求时,Vite 会拦截这个请求,并按照配置进行处理。target 指定了目标服务器的地址,这里是http://personalpile.admin.usteu.com/,意味着这个请求会被转发到该服务器。

changeOrigin 设置为 true 是一个很重要的配置,它表示在发送请求到目标服务器时,会修改请求头中的 Origin 字段,让目标服务器以为请求来自于它自己所在的域,从而避免一些服务器可能存在的域名验证限制。

rewrite 则用于修改请求路径。这里的path.replace(/^/dev-api/, ‘’)表示会把请求路径中开头的/dev-api去掉。原来的请求路径是/dev-api/PileManager/some/path,经过重写后就变成了/PileManager/some/path,然后再拼接上 target 的地址,最终请求的实际地址就是http://personalpile.admin.usteu.com/PileManager/some/path。

再看第二个代理规则"/dev-api"。这里你可能会疑惑,它的路径前缀看起来和第一个规则有重叠,为什么能正常工作?这是因为 Vite 在匹配代理规则时,会优先选择更具体、更长的路径前缀。只有当请求路径不匹配第一个规则时,才会匹配这个更通用的规则。

这个规则的 target 设置为本地的http://localhost:8050/,通常这是开发者自己的后端服务。rewrite 这里使用了env.VITE_APP_BASE_API,这是一个从环境变量中获取的值,通常也是/dev-api。所以这个重写规则的意思是,把请求路径中开头的/dev-api替换成/api。比如原来的请求是/dev-api/user/list,重写后就变成了/api/user/list,最终请求的实际地址是http://localhost:8050/api/user/list。

通过这样的代理配置,前端开发者就不需要在代码中硬编码不同环境的接口地址,也不需要担心开发阶段的跨域问题。Vite 会自动帮我们完成请求的转发和路径的处理,让我们可以专注于业务逻辑的开发。

需要注意的是,这些代理配置只在开发阶段生效,因为它是 Vite 开发服务器提供的功能。当项目打包上线到生产环境时,通常会使用 Nginx 等服务器来配置类似的反向代理功能,以确保生产环境中的接口请求也能正常工作。

那么nginx大概应该怎么配置呢,如下示例:

location /dev-api/PileManager/ {proxy_pass http://personalpile.admin.usteu.com/PileManager/;proxy_set_header Host personalpile.admin.usteu.com;proxy_set_header X-Real-IP $remote_addr;proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;proxy_set_header X-Forwarded-Proto $scheme;
}location /dev-api/ {proxy_pass http://127.0.0.1:8050/api/;# 连接增强配置client_max_body_size 1000m;send_timeout 3600s;keepalive_timeout 3600s;         # 保持连接活性(网页7补充)keepalive_requests 10000;       # 单连接最大请求数# SSE核心配置proxy_http_version 1.1;          # 强制使用HTTP/1.1协议(网页1、网页6)proxy_set_header Upgrade $http_upgrade;proxy_set_header Connection "upgrade";#关闭代理缓冲,确保实时传输proxy_buffering off;proxy_cache off;                # 关闭缓存防止数据截断proxy_read_timeout 86400s;      # 24小时超时(网页1建议值)proxy_set_header Cache-Control 'no-cache';add_header Cache-Control no-cache;# 头信息增强proxy_set_header X-Accel-Buffering no;# 下面三句话是用来获取用户访问的ip的proxy_set_header Host             $host;proxy_set_header X-Real-IP        $remote_addr;proxy_set_header X-Forwarded-For  $proxy_add_x_forwarded_for;proxy_set_header Last-Event-ID $http_last_event_id;# CORS跨域支持(网页3、网页5)add_header 'Access-Control-Allow-Origin' $http_origin always;add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS' always;add_header 'Access-Control-Allow-Headers' 'Content-Type,Authorization,Last-Event-ID' always;add_header 'Access-Control-Expose-Headers' 'Content-Type,Content-Length' always;# 预检请求处理(网页2、网页6)if ($request_method = OPTIONS) {add_header 'Access-Control-Max-Age' 1728000;add_header 'Access-Control-Allow-Headers' 'Content-Type, Authorization, Last-Event-ID';add_header 'Content-Type' 'text/plain; charset=utf-8';return 204;}
}

以上展示了当我们的前端需要调用其他第三方服务器的接口时,我们在本地开发环境和线上生产环境分别需要做的事,笔者展示了详细的代理示例,希望给大家带来参考价值。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/news/917102.shtml
繁体地址,请注明出处:http://hk.pswp.cn/news/917102.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

理解梯度在神经网络中的应用

梯度(Gradient)是微积分中的一个重要概念,广泛应用于机器学习和深度学习中,尤其是在神经网络的训练过程中。下面将从梯度的基本概念、其在神经网络中的应用两个方面进行详细介绍。一、梯度的基本概念 1.1 什么是梯度? …

WPF,按钮透明背景实现MouseEnter

在帮手程序(assister.exe)中,可以点击录制按钮,实现录制用户操作直接生成操作列表。而在弹出录制按钮的悬浮窗中,需要能够拖动录制按钮放置在任意的位置,以免阻挡正常的窗口。具体功能是,当鼠标…

【抄袭】思科交换机DAI(动态ARP监控)配置测试

一.概述 1.DAI作用 ①.使用DAI,管理员可以指定交换机的端口为信任和非信任端口: 信任端口可以转发任何ARP信息 非信任端口的ARP消息要进行ARP检测验证 ②.交换机执行如下的ARP验证: 静态ARP监控:为一个静态的IP地址配置一个静态AR…

在嵌入式系统或 STM32 平台中常见的外设芯片和接口

在嵌入式系统或 STM32 平台中常见的 外设芯片 或 模块名称,包括: 📺 显示驱动(如 ST7735、OTM8009A、NT35510)📷 摄像头模组(如 OV5640、OV9655、S5K5CAG)💾 Flash 存储器…

AI 类型的 IDE

指集成了 AI 辅助编程能力的集成开发环境 一、代码辅助生成 ✅ 自动补全(更智能) 比传统 IDE 更智能,理解上下文,生成整个函数/模块 示例:根据函数名 calculateTax 自动生成税务计算逻辑 ✅ 函数 / 类自动生成 给…

JP3-3-MyClub后台后端(一)

Java道经 - 项目 - MyClub - 后台后端(一) 传送门:JP3-1-MyClub项目简介 传送门:JP3-2-MyClub公共服务 传送门:JP3-3-MyClub后台后端(一) 传送门:JP3-3-MyClub后台后端(…

架构实战——互联网架构模板(“存储层”技术)

目录 一、SQL 二、NoSQL 三、小文件存储 四、大文件存储 本文来源:极客时间vip课程笔记 一、SQL SQL 即我们通常所说的关系数据。前几年 NoSQL 火了一阵子,很多人都理解为 NoSQL 是完全抛弃关系数据,全部采用非关系型数据。但经过几年的试验后,大家发现关系数据不可能完全被…

CentOS7.9在线部署Dify

一、CentOS7.9安装dify 二、检查是否安装dcoker docker --version2.1下载后将安装包上传至服务器对应文件夹下,我选在放在了 /root文件夹下 cd /root2.2 上传至服务器 cd /root #对应目录下tar -xvf docker-26.1.4.tgz # 解压安装包:chmod 755 -R docker # 赋予可执…

深入浅出C语言指针:从数组到函数指针的进阶之路(中)

指针是C语言的灵魂,也是初学者最头疼的知识点。它像一把锋利的刀,用得好能大幅提升代码效率,用不好则会让程序漏洞百出。今天这篇文章,我们从数组与指针的基础关系讲起,一步步揭开指针进阶类型的神秘面纱,最…

java web Cookie处理

java web 设置cookie更改启动端口// Directory tree (5 levels) ├── src\ │ ├── a.txt │ └── com\ │ └── zhang\ │ └── ServletContext\ │ ├── cookie\ │ └── servletContext.java └── web\├─…

机器学习—线性回归

一线性回归线性回归是利用数理统计中回归分析,来确定两种或两种以上变量间相互依赖的定量关系的一种统计分析方法。相关关系:包含因果关系和平行关系因果关系:回归分析【原因引起结果,需要明确自变量和因变量】平行关系&#xff1…

Spring Boot Admin 监控模块笔记-实现全链路追踪

一、概述Spring Boot Admin(SBA)是一个用于监控和管理 Spring Boot 应用程序的工具。它提供了一个 Web 界面,可以集中管理多个 Spring Boot 应用程序的健康状态、指标、日志、配置等信息。通过 SBA,你可以轻松地监控和管理你的微服…

容器化与Docker核心原理

目录 专栏介绍 作者与平台 您将学到什么? 学习特色 容器化与Docker核心原理 引言:为什么容器化成为云计算时代的基石? 容器化技术全景与Docker核心原理:从概念到实践 文章摘要 1. 引言:为什么容器化成为云计算…

掌握Python三大语句:顺序、条件与循环

PS不好意思各位,由于最近笔者在参加全国大学生电子设计大赛,所以最近会出现停更的情况,望大家谅解,比赛结束后我会加大力度,火速讲Python的知识给大家写完🎖️🎖️🎖️🎖…

JAVA结合AI

Java 与人工智能(AI)的结合正经历从技术探索到深度融合的关键阶段。以下从技术生态、应用场景、工具创新、行业实践及未来趋势五个维度展开分析,结合最新技术动态与企业级案例,揭示 Java 在 AI 时代的独特价值与发展路径。一、技术…

本土DevOps平台Gitee如何重塑中国研发团队的工作流

本土DevOps平台Gitee如何重塑中国研发团队的工作流 在数字化转型浪潮席卷各行各业的当下,软件开发效率已成为企业竞争力的核心指标。Gitee DevOps作为专为中国开发团队打造的本土化研发管理平台,正在改变国内技术团队的工作方式。该平台通过从代码管理到…

5G MBS(组播广播服务)深度解析:从标准架构到商用实践

一、MBS技术背景与核心价值 1.1 业务需求驱动 随着超高清视频(4K/8K)、多视角直播、XR元宇宙应用爆发式增长,传统单播传输面临带宽浪费(相同内容重复发送)与拥塞风险(万人并发场景)的双重挑战。5G MBS通过点对多点(PTM)传输实现内容一次发送、多终端接收,频谱效率提…

如何将照片从 realme 手机传输到电脑?

对于 realme 用户来说,将照片传输到电脑可以有多种用途,从释放设备空间到在单独的存储设备上创建备份。这个过程不仅有助于高效管理设备内存,还可以让您利用电脑上强大的照片编辑软件进行高级增强和创意项目。了解如何将照片从 realme 手机传…

Centos 7部署.NET 8网站项目

简介 本文详细介绍了在CentOS 7系统上部署.NET 8网站项目的完整流程,主要内容包括:系统版本更新与检查、PostgreSQL数据库的安装配置(含防火墙设置、数据库初始化及远程访问配置)、Nginx Web服务的安装与防火墙配置。文章通过分步…

Windows 11下IDEA中使用git突然变得卡慢及解决办法

1. 表象 使用idea的git进行update、commit、push等操作时,极度卡慢。需等待几十秒到几分钟。修改文件后,git刷新也不及时。update命令有时候无法点击。 2.解决方法 停止PC Manager ServiceCtrl shift esc : 打开任务管理器找到服务: 服务中…