解决React和Python Flask不共用端口的问题

news/2024/9/25 21:19:36/

React和Flask不共用端口的一个常见方法是使用不同的端口分别运行它们,然后使用代理将它们连接起来。在开发环境中,您可以配置React的开发服务器(使用create-react-app创建的React应用)代理请求到Flask服务器。生产环境中,您可以使用Nginx等反向代理服务器来处理这种情况。

开发环境配置

在开发环境中,您可以在React项目的package.json文件中添加一个proxy字段,将API请求代理到Flask服务器。

步骤如下:
  1. 确保React和Flask在不同端口运行

    • React开发服务器默认运行在3000端口。
    • Flask服务器可以在5000端口运行。
  2. 在React项目的package.json中添加proxy字段

package.json中添加以下字段:

"proxy": "http://localhost:5000"

启动Flask服务器 

确保您的Flask应用运行在5000端口。可以通过以下命令启动:

export FLASK_APP=app.py
export FLASK_ENV=development
flask run --port 5000

启动React开发服务器 

在React项目的根目录下运行:

npm start

现在,当您在React应用中发出API请求时,例如使用axios.get('/api/orders'),React开发服务器会自动将这些请求代理到运行在5000端口的Flask服务器。

生产环境配置

在生产环境中,通常会使用Nginx等反向代理服务器来管理前后端的请求。

Nginx配置示例

假设您的React应用已经打包(使用npm run build命令),并且打包后的文件存储在服务器上的某个目录中,以下是一个Nginx配置示例:

server {listen 80;server_name your_domain.com;location / {root /path_to_your_react_build;try_files $uri /index.html;}location /api/ {proxy_pass http://localhost:5000;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 X-Forwarded-Proto $scheme;}
}

在这个配置中:

  • Nginx会处理根路径(/)的请求并返回React应用的静态文件。
  • /api/路径的请求会被代理到运行在5000端口的Flask服务器。

通过上述配置,React和Flask可以在不同的端口运行,且开发和生产环境都可以正常工作。开发环境使用React开发服务器的代理功能,生产环境使用Nginx等反向代理服务器。


http://www.ppmy.cn/news/1463524.html

相关文章

一个投稿好方法让你的文章早日发表

作为一名单位信息宣传员,我初入此行时,满腔热情,怀揣着传播单位价值、展示团队风采的理想,一头扎进了稿件撰写的海洋。我的目标很简单,就是通过文字的力量,让外界听到我们的声音,感受到我们的活力。然而,理想很丰满,现实却给我上了生动的一课。 起初,我遵循传统路径,选择了一家…

力扣HOT100 - 287. 寻找重复数

解题思路: 快慢指针 第一步,慢指针每次移动一步,快指针每次移动两步,直到它们相遇。这一步保证了它们在环中相遇。 接下来,将其中一个指针(快指针或慢指针)重置到起点(即数组的第一…

使用JSON_EXTRACT匹配某个json类型字段中的某个具体字段

使用JSON_EXTRACT匹配某个json类型字段中的某个具体字段 1. 使用场景2. 来自ChatGPT的JSON_EXTRACT使用说明 1. 使用场景 如果你有一张表table,其中有一个字段attrs,并且该字段是一个json,其中又包括totalPrice、skuPrice、couponPrice三个字…

2024新数据库入门教程

1.官网下载MySQL 下载Mysql链接: 点击下载mysql 下载完成后解压到某一个文件夹(记住这个路径,一会要用到) 2.配置初始化文件my.ini 在根目录下创建一个txt文件,名字叫my,文件后缀为ini 以下代码除安装目录和数…

001.数据分析_NumPy

我 的 个 人 主 页:👉👉 失心疯的个人主页 👈👈 入 门 教 程 推 荐 :👉👉 Python零基础入门教程合集 👈👈 虚 拟 环 境 搭 建 :👉&…

使用 Python 编程语言进行供应链分析

前言 要分析一家公司的供应链,我们需要供应链不同阶段的数据,如有关采购、制造、运输、库存管理、销售和客户人口统计的数据。我为这项任务找到了一个理想的数据集,其中包括一家时尚和美容初创公司的供应链数据。 1. 相关数据集 让我们导入…

MyBatis的基础操作

目录 一.什么是MyBatis? 二.使用MyBatis的准备工作 1.引入依赖: 2.配置数据库连接字符串(建立MaBatis和MySQL的连接) 3.在model包中建立数据库对应的实体类UserInfo 三.通过注解的方式实现MyBatis的开发 1.插入语句(Insert) 2.删除语句(Delete) 3.更新语句(Update) 4…

MyBatis复习笔记

3.Mybatis复习 3.1 xml配置 properties&#xff1a;加载配置文件 settings&#xff1a;设置驼峰映射 <settings><setting name"mapUnderscoreToCamelCase" value"true"/> </settings>typeAliases&#xff1a;类型别名设置 #这样在映射…