python - 在两个单独的 Heroku 应用程序上代理从 React 前端到 Flask 后端的 API 请求
问题描述
我正在开发一个带有 create-react-app 前端和带有 Flask-RESTful 的 Flask API 后端的 Web 应用程序。我在本地构建了该应用程序,它可以在我的计算机上运行,但现在我尝试将其部署到 Heroku 失败了。
我将 Flask 后端和 React 前端部署为两个不同的 Heroku dyno,所以每个都有自己的 URL。当我转到前端的 URL 时,它似乎工作正常,后端 URL 似乎也工作。但是,该应用程序依赖于对后端的 API 调用,我无法成功地将请求发送到我的后端。
当我在本地工作时,我会gunicorn --bind 0.0.0.0:8000 app:app
使用命令运行烧瓶后端和前端npm start
。只要我将文件放入前端应用程序,该应用程序就可以很好地处理我的 Axios 函数调用中的相关"proxy": "https://localhost:8000"
调用package.json
。一般来说,我遵循本教程:https ://www.fullstackreact.com/articles/using-create-react-app-with-a-server/ 。
我想我可以简单地编辑文件中的proxy
字段package.json
以指向我的后端 Heroku 应用程序的 URL,然后我不必更改任何其他内容。但是,当我使用它进行部署时,我发现对我的端点的请求是针对https://my-frontend-app.herokuapp.com/<endpoint>
而不是https://my-backend-app.herokuapp.com/<endpoint>
.
这是我的 package.json:
{
"name": "heroku-app",
"version": "0.1.0",
"private": true,
"dependencies": {
"axios": "^0.18.0",
"bootstrap": "^4.1.2",
"plotly.js": "^1.39.2",
"react": "^16.4.1",
"react-dom": "^16.4.1",
"react-plotly.js": "^2.2.0",
"react-scripts": "1.1.4",
"reactstrap": "^6.3.0"
},
"scripts": {
"start": "react-scripts start",
"build": "react-scripts build",
"test": "react-scripts test --env=jsdom",
"eject": "react-scripts eject"
},
"proxy": "https://star-employees-api.herokuapp.com"
}
我的请求如下所示:
axios.get('/analyze', data)
.then((response) => {
// Handle request response here
};
谁能告诉我我在这里做错了什么?这是我第一次部署这样的应用程序并使用 Heroku,所以我不确定我是否离这里很远。如果有更好的方法来部署这种应用程序,也请告诉我。如果有帮助,我可以提供任何其他代码片段或文件结构,只是不确定此时会有什么帮助。提前致谢。
解决方案
推荐阅读
- node.js - 正在寻找使用 Hyperledger Fabric 和 Composer REST SERVER 开发 NodeJs 区块链应用程序的端到端教程
- javascript - 使用节点创建文件并使用提示输入替换变量
- selenium - 浏览器加载程序运行时如何在弹出窗口中与 webelement 交互?
- mysql - 如何在 MySQL 触发器中创建复杂的 IF 条件
- node.js - 如何从 Nodejs 应用程序容器中使用 mongodump 命令?
- sharepoint-2013 - 在 SharePoint 列表中按 ID 获取多个列表项
- android - TabLayout 中的 CardView
- python - 在 python 中导入 rds 文件以作为数据框读取
- hibernate - 在不破坏 gradle 测试的情况下使用 Hibernate 映射 PostgreSQL 数组
- angular - 需要根据下拉列表中选择的选项显示学生列表