react如何进行项目配置代理

目录

一、前言

二、配置方法

三、总结


 前言:

在使用React创建应用程序时,配置代理的目的是为了解决跨域请求的问题。跨域请求是指在浏览器中,一个站点的Web应用程序向另一个不同域名的站点发送请求。由于浏览器的安全策略,这些跨域请求通常会被阻止。

通过配置代理,我们可以将所有的API请求发送到同一域名下,然后在该域名下进行代理转发到实际的API服务器上。这样就绕过了浏览器的跨域请求限制,使得我们可以在开发环境中顺利地进行。


配置方法:

、要在React项目中进行代理配置,你可以使用http-proxy-middleware库。以下是配置代理的步骤:
  1. 安装http-proxy-middleware库:

    npm install http-proxy-middleware --save
  2. 在项目根目录下创建一个名为setupProxy.js的文件。

  3. setupProxy.js文件中,导入http-proxy-middleware库和需要代理的请求地址:

    const { createProxyMiddleware } = require('http-proxy-middleware');module.exports = function(app) {app.use('/api',createProxyMiddleware({target: 'http://your_api_server_address',changeOrigin: true,}));
    };

    这里假设你的API服务器地址为http://your_api_server_address,并且你希望将以/api开头的请求代理到该地址上。

  4. 启动开发服务器时,create-react-app会自动检测并加载setupProxy.js文件中的代理配置。所以你无需进行其他额外的配置。

  5. 现在,当你在React应用中发起以/api开头的请求时,它们将被代理到指定的API服务器地址。

二、要在React项目中进行代理配置,你可以使用以下步骤:
  1. 在根目录下创建一个 setupProxy.js 文件。

  2. 在 setupProxy.js 中配置代理,示例如下:

    const { createProxyMiddleware } = require('http-proxy-middleware');module.exports = function(app) {app.use('/api',createProxyMiddleware({target: 'http://localhost:3001',changeOrigin: true,// pathRewrite: {//   '^/api': '',// },}));
    };

  3. 复制插入

    上面的配置代表将 /api 请求转发到 http://localhost:3001 服务器。

    target 代表目标服务器的地址,可以是一个字符串或一个对象。

    changeOrigin 代表是否改变请求头中的源地址,在使用反向代理时需要设置为 true

    pathRewrite 可以用于替换请求路径,如上面代码中的注释所示,如果请求路径中包含 /api,则替换为空字符串。

  4.  package.json 的 scripts 中添加 "start": "react-scripts start & node server.js",其中 server.js 是你的后端服务器入口文件。

  5. 运行 npm start 启动项目,此时访问 /api 路径会被代理到 http://localhost:3001 服务器。

注意:

  • http-proxy-middleware 应该作为 devDependencies 安装。

  • 如果你已经有了使用 Express、Koa 等构建的后端服务器,则不需要在 setupProxy.js 中配置代理,可以将请求直接发往后端服务器。

总结:

在网络通信中,代理服务器扮演着非常重要的角色,它可以提高网络传输的速度、保护用户隐私、解决网络限制和防御网络攻击等。

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

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

相关文章

uniapp开发小程序接入阿里云TTS语音合成(RESTful API)

流程 首先小程序后台配置白名单 1.1 路径:开发-开发管理-开发设置-服务器域名-request合法域名 1.2 request合法域名参数: https://nls-meta.cn-shanghai.aliyuncs.com https://nls-gateway-cn-shanghai.aliyuncs.com引入alitts.js页面使用…

解决方案中word中分节符的使用

解决方案中必不可少的两个“符号”,分页符,分节符 有了分节符,可以为不同节设置不同的页眉页脚、分栏格式、纸张大小及方向、页边距、不同节间采用不同的页码序号,常用的功能主要是把word下一次的由原来的“竖版”,变…

Tomcat10 简单地enable Https

通常来讲, 建站后要启用https 有下面3个步骤 1.购买域名 2.绑定域名和 服务器的外部IP地址 3.为这域名购买SSL 证书 (还有其密码) 4.在Tomcat上启用https 和安装这个证书 但是其实没有域名也可以在tomcat 中enable https的, 至于…

VSIX:C#项目 重命名所有标识符(Visual Studio扩展开发)

出于某种目的(合法的,真的合法的,合同上明确指出可以这样做),我准备了一个重命名所有标识符的VS扩展,用来把一个C#库改头换面,在简单的测试项目上工作很满意,所有标识符都被准确替换…

angular、 react、vue框架对比

借鉴:Web前端开发:三大主流框架 (baidu.com) AngularReactVue公司ChromeFaceBook尤雨溪写法有指令、模板的概念比较灵活,没有要求使用特定的架构和模式有指令和模板的概念性能低有虚拟Dom,性能高有虚拟Dome,性能高学习门槛 高&am…

SpringBoot-SpringCache缓存

文章目录 Spring Cache 介绍常用注解 Spring Cache 介绍 Spring Cache 是一个框架,实现了基于注解的缓存功能,只需要简单地加一个注解,就能实现缓存功能。 Spring Cache 提供了一层抽象,底层可以切换不同的缓存实现,…

产品经理入门学习(一):认识产品经理

参考引用 黑马-产品经理入门基础课程 1. 合格的产品经理 1.1 什么是产品 上述产品的共性:解决某个问题的东西上述产品的区别 有形(上图左):颜色、形状、质地和尺寸无形(上图右):脑力劳动成果、…

STM32WB55开发(6)----FUS更新

STM32WB55开发.6--FUS更新 概述视频教学硬件准备存储器映射FLASH安全区设置SRAM安全区设置通过USB进行下载注意事项 概述 在 STM32WB 微控制器中,FUS(Firmware Upgrade Services)是用于固件升级的一种服务。这项服务可以让你更新设备上的无…

vue3视频大小适配浏览器窗口大小

目标:按浏览器窗口的大小,平铺视频,来适配屏幕的大小。 考虑使用 DPlayer.js、video.js、vue-video-player等视频插件,但报了各种各样的错;试过使用 js 对视频进行同比例放大,再判断其与窗口的大小取最小值…

按键精灵中常用的命令

1. 声明变量: Dim 2. 注释语句 (1). 单行注释:这是一行注释,使用一个单引号进行注释; (2). 单行注释:// 这是一行注释,使用一对反斜杠进行注释; (3). 多行注释:/*这是多行注释,中…

R语言_RColorBrewer包--全平台可用

R语言_RColorBrewer包–全平台可用

springboot整合redis+lua实现getdel操作保证原子性

原始代码 脚本逻辑先获取redis的值,判断是否等于期望值。 条件成立则删除,不成立则返回0 if redis.call(get, KEYS[1]) ARGV[1] thenreturn redis.call(del, KEYS[1]) end return 0 测试代码 根据上面的逻辑加了测试, 在判断成功后等待5…

送你几款开源IDC资产管理系统

更多运维技术,请关注微信公众号“运维之美” 送你几款开源IDC资产管理系统 1.phpIPAM2.NetBox3.IPPlan4.GestiIP5.RackTables 对于公司机房运维人员来说,你的idc资产管理清单可能还记录在各种excel表格中,当设备和ip变动的时候进行手动更新&a…

解锁无限可能:ON1 Photo RAW的新功能与优势forMac/win

作为摄影师,您是否曾为繁琐的照片编辑过程而感到困扰?是否希望有一种工具,能将您的照片编辑过程变得更加高效、灵活,同时不损失画质?如果是,那么您一定不能错过ON1 Photo RAW。 ON1 Photo RAW是一款全新的…

Spring Boot整合Swagger

🙈作者简介:练习时长两年半的Java up主 🙉个人主页:程序员老茶 🙊 ps:点赞👍是免费的,却可以让写博客的作者开心好久好久😎 📚系列专栏:Java全栈,…

奇元大模型通过备案 360自研两大模型均获批

11月4日,三六零(601360.SH,下称“360”)大模型“奇元大模型”通过备案落地。今年9月,“360智脑大模型”已获批面向公众开放。360公司也成为国内首家两个大模型均通过备案的科技企业。 从大模型定位和应用角度来看,奇元大模型具备…

单目标应用:粒子群优化算法(PSO)求解微电网优化MATLAB

一、微网系统运行优化模型 微电网优化模型介绍: 微电网多目标优化调度模型简介_IT猿手的博客-CSDN博客 二、粒子群优化算法(PSO)求解微电网优化 (1)部分代码 close all; clear ; clc; global P_load; %电负荷 gl…

蓝桥杯官网填空题(黄金连分数)

题目描述 本题为填空题,只需要算出结果后,在代码中使用输出语句将所填结果输出即可。 黄金分割数 0.61803... 是个无理数,这个常数十分重要,在许多工程问题中会出现。有时需要把这个数字求得很精确。 对于某些精密工程&#xf…

Android Gldie复用只取之前decode过的缓存resource,Kotlin

Android Gldie复用只取之前decode过的缓存resource,Kotlin import android.graphics.Bitmap import android.os.Bundle import android.util.Log import android.widget.ImageView import androidx.appcompat.app.AppCompatActivity import androidx.lifecycle.life…

Java,面向对象,枚举类

枚举类型本质上也是一种类,只不过这个类的对象是有限的、固定的几个,不能让用户随意创建。 场景: 开发中,如果针对于某个类,它的实例的个数是确定的。则推荐将此类声明为枚举类。 如果枚举类的实例只有一个&#xff0c…