full-stack-fastapi-template

full-stack-fastapi-template

现代全栈开发框架 整合FastAPI React与Docker

Full-stack-fastapi-template是一个集成FastAPI、React和Docker的全栈开发框架。它提供后端API、前端界面和数据库集成,包含用户认证、邮件恢复、测试和CI/CD等功能。该框架支持暗黑模式和自动HTTPS配置,为开发者创建高效、安全的全栈环境。

FastAPI全栈开发Docker ComposeReactPostgreSQLGithub开源项目

FastAPI 全栈模板

<a href="https://github.com/fastapi/full-stack-fastapi-template/actions?query=workflow%3ATest" target="_blank"><img src="https://yellow-cdn.veclightyear.com/835a84d5/b32fbd0e-261c-4c2d-b17f-cdfcb13f1b7d.svg" alt="测试"></a> <a href="https://coverage-badge.samuelcolvin.workers.dev/redirect/fastapi/full-stack-fastapi-template" target="_blank"><img src="https://coverage-badge.samuelcolvin.workers.dev/fastapi/full-stack-fastapi-template.svg" alt="覆盖率"></a>

技术栈和特性

  • FastAPI 用于 Python 后端 API。
    • 🧰 SQLModel 用于 Python SQL 数据库交互(ORM)。
    • 🔍 Pydantic,由 FastAPI 使用,用于数据验证和设置管理。
    • 💾 PostgreSQL 作为 SQL 数据库。
  • 🚀 React 用于前端。
    • 💃 使用 TypeScript、钩子、Vite 和其他现代前端技术栈组件。
    • 🎨 Chakra UI 用于前端组件。
    • 🤖 自动生成的前端客户端。
    • 🧪 Playwright 用于端到端测试。
    • 🦇 支持暗黑模式。
  • 🐋 Docker Compose 用于开发和生产。
  • 🔒 默认安全的密码哈希。
  • 🔑 JWT(JSON Web Token)身份验证。
  • 📫 基于邮件的密码恢复。
  • ✅ 使用 Pytest 进行测试。
  • 📞 Traefik 作为反向代理/负载均衡器。
  • 🚢 使用 Docker Compose 的部署说明,包括如何设置前端 Traefik 代理以处理自动 HTTPS 证书。
  • 🏭 基于 GitHub Actions 的 CI(持续集成)和 CD(持续部署)。

仪表板登录

API 文档

仪表板 - 管理员

API 文档

仪表板 - 创建用户

API 文档

仪表板 - 项目

API 文档

仪表板 - 用户设置

API 文档

仪表板 - 暗黑模式

API 文档

交互式 API 文档

API 文档

如何使用

你可以直接 fork 或克隆这个仓库并按原样使用。

✨ 它可以直接使用。✨

如何使用私有仓库

如果你想拥有一个私有仓库,GitHub 不允许你简单地 fork 它,因为它不允许更改 fork 的可见性。

但你可以执行以下操作:

  • 创建一个新的 GitHub 仓库,例如 my-full-stack
  • 手动克隆这个仓库,设置名称为你想使用的项目名称,例如 my-full-stack
git clone git@github.com:fastapi/full-stack-fastapi-template.git my-full-stack
  • 进入新目录:
cd my-full-stack
  • 将新的 origin 设置为你的新仓库,从 GitHub 界面复制它,例如:
git remote set-url origin git@github.com:octocat/my-full-stack.git
  • 将此仓库添加为另一个"远程",以便日后获取更新:
git remote add upstream git@github.com:fastapi/full-stack-fastapi-template.git
  • 将代码推送到你的新仓库:
git push -u origin master

从原始模板更新

克隆仓库并进行修改后,您可能想获取原始模板的最新更改。

  • 确保您已将原始仓库添加为远程仓库,可以通过以下命令检查:
git remote -v origin git@github.com:octocat/my-full-stack.git (fetch) origin git@github.com:octocat/my-full-stack.git (push) upstream git@github.com:fastapi/full-stack-fastapi-template.git (fetch) upstream git@github.com:fastapi/full-stack-fastapi-template.git (push)
  • 拉取最新更改但不合并:
git pull --no-commit upstream master

这将下载此模板的最新更改但不提交,这样您可以在提交前检查一切是否正确。

  • 如果有冲突,在编辑器中解决它们。

  • 完成后,提交更改:

git merge --continue

配置

然后您可以更新 .env 文件中的配置以自定义您的设置。

在部署之前,请确保至少更改以下值:

  • SECRET_KEY
  • FIRST_SUPERUSER_PASSWORD
  • POSTGRES_PASSWORD

您可以(也应该)从密钥中以环境变量的形式传递这些值。

查阅 deployment.md 文档了解更多细节。

生成密钥

.env 文件中的一些环境变量默认值为 changethis

您必须将它们更改为密钥,要生成密钥,可以运行以下命令:

python -c "import secrets; print(secrets.token_urlsafe(32))"

复制内容并将其用作密码/密钥。再次运行该命令以生成另一个安全密钥。

如何使用 - 使用 Copier 的替代方法

本仓库还支持使用 Copier 生成新项目。

它会复制所有文件,询问您配置问题,并用您的答案更新 .env 文件。

安装 Copier

您可以通过以下方式安装 Copier:

pip install copier

或者更好的是,如果您有 pipx,可以运行:

pipx install copier

注意:如果您有 pipx,安装 copier 是可选的,您可以直接运行它。

使用 Copier 生成项目

为您的新项目目录决定一个名称,您将在下面使用它。例如,my-awesome-project

转到将作为项目父目录的目录,并使用您的项目名称运行以下命令:

copier copy https://github.com/fastapi/full-stack-fastapi-template my-awesome-project --trust

如果您有 pipx 但没有安装 copier,可以直接运行:

pipx run copier copy https://github.com/fastapi/full-stack-fastapi-template my-awesome-project --trust

注意 --trust 选项是必要的,以便能够执行一个创建后脚本来更新您的 .env 文件。

输入变量

Copier 会询问您一些数据,在生成项目之前您可能想准备好这些信息。

但不用担心,之后您可以在 .env 文件中更新任何内容。

输入变量及其默认值(一些自动生成)如下:

  • project_name:(默认:"FastAPI Project")项目名称,显示给 API 用户(在 .env 中)。
  • stack_name:(默认:"fastapi-project")用于 Docker Compose 标签和项目名称的堆栈名称(无空格,无句点)(在 .env 中)。
  • secret_key:(默认:"changethis")项目的密钥,用于安全,存储在 .env 中,您可以使用上述方法生成一个。
  • first_superuser:(默认:"admin@example.com")第一个超级用户的邮箱(在 .env 中)。
  • first_superuser_password:(默认:"changethis")第一个超级用户的密码(在 .env 中)。
  • smtp_host:(默认:"")用于发送邮件的 SMTP 服务器主机,您可以稍后在 .env 中设置。
  • smtp_user:(默认:"")用于发送邮件的 SMTP 服务器用户,您可以稍后在 .env 中设置。
  • smtp_password:(默认:"")用于发送邮件的 SMTP 服务器密码,您可以稍后在 .env 中设置。
  • emails_from_email:(默认:"info@example.com")用于发送邮件的邮箱账户,您可以稍后在 .env 中设置。
  • postgres_password:(默认:"changethis")PostgreSQL 数据库的密码,存储在 .env 中,您可以使用上述方法生成一个。
  • sentry_dsn:(默认:"")Sentry 的 DSN,如果您使用它,可以稍后在 .env 中设置。

后端开发

后端文档:backend/README.md

前端开发

前端文档:frontend/README.md

部署

部署文档:deployment.md

开发

通用开发文档:development.md

这包括使用 Docker Compose、自定义本地域名、.env 配置等。

发布说明

查看文件 release-notes.md

许可证

Full Stack FastAPI模板根据MIT许可证的条款授权使用。

编辑推荐精选

讯飞智文

讯飞智文

一键生成PPT和Word,让学习生活更轻松

讯飞智文是一个利用 AI 技术的项目,能够帮助用户生成 PPT 以及各类文档。无论是商业领域的市场分析报告、年度目标制定,还是学生群体的职业生涯规划、实习避坑指南,亦或是活动策划、旅游攻略等内容,它都能提供支持,帮助用户精准表达,轻松呈现各种信息。

AI办公办公工具AI工具讯飞智文AI在线生成PPTAI撰写助手多语种文档生成AI自动配图热门
讯飞星火

讯飞星火

深度推理能力全新升级,全面对标OpenAI o1

科大讯飞的星火大模型,支持语言理解、知识问答和文本创作等多功能,适用于多种文件和业务场景,提升办公和日常生活的效率。讯飞星火是一个提供丰富智能服务的平台,涵盖科技资讯、图像创作、写作辅助、编程解答、科研文献解读等功能,能为不同需求的用户提供便捷高效的帮助,助力用户轻松获取信息、解决问题,满足多样化使用场景。

热门AI开发模型训练AI工具讯飞星火大模型智能问答内容创作多语种支持智慧生活
Spark-TTS

Spark-TTS

一种基于大语言模型的高效单流解耦语音令牌文本到语音合成模型

Spark-TTS 是一个基于 PyTorch 的开源文本到语音合成项目,由多个知名机构联合参与。该项目提供了高效的 LLM(大语言模型)驱动的语音合成方案,支持语音克隆和语音创建功能,可通过命令行界面(CLI)和 Web UI 两种方式使用。用户可以根据需求调整语音的性别、音高、速度等参数,生成高质量的语音。该项目适用于多种场景,如有声读物制作、智能语音助手开发等。

Trae

Trae

字节跳动发布的AI编程神器IDE

Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。

AI工具TraeAI IDE协作生产力转型热门
咔片PPT

咔片PPT

AI助力,做PPT更简单!

咔片是一款轻量化在线演示设计工具,借助 AI 技术,实现从内容生成到智能设计的一站式 PPT 制作服务。支持多种文档格式导入生成 PPT,提供海量模板、智能美化、素材替换等功能,适用于销售、教师、学生等各类人群,能高效制作出高品质 PPT,满足不同场景演示需求。

讯飞绘文

讯飞绘文

选题、配图、成文,一站式创作,让内容运营更高效

讯飞绘文,一个AI集成平台,支持写作、选题、配图、排版和发布。高效生成适用于各类媒体的定制内容,加速品牌传播,提升内容营销效果。

热门AI辅助写作AI工具讯飞绘文内容运营AI创作个性化文章多平台分发AI助手
材料星

材料星

专业的AI公文写作平台,公文写作神器

AI 材料星,专业的 AI 公文写作辅助平台,为体制内工作人员提供高效的公文写作解决方案。拥有海量公文文库、9 大核心 AI 功能,支持 30 + 文稿类型生成,助力快速完成领导讲话、工作总结、述职报告等材料,提升办公效率,是体制打工人的得力写作神器。

openai-agents-python

openai-agents-python

OpenAI Agents SDK,助力开发者便捷使用 OpenAI 相关功能。

openai-agents-python 是 OpenAI 推出的一款强大 Python SDK,它为开发者提供了与 OpenAI 模型交互的高效工具,支持工具调用、结果处理、追踪等功能,涵盖多种应用场景,如研究助手、财务研究等,能显著提升开发效率,让开发者更轻松地利用 OpenAI 的技术优势。

Hunyuan3D-2

Hunyuan3D-2

高分辨率纹理 3D 资产生成

Hunyuan3D-2 是腾讯开发的用于 3D 资产生成的强大工具,支持从文本描述、单张图片或多视角图片生成 3D 模型,具备快速形状生成能力,可生成带纹理的高质量 3D 模型,适用于多个领域,为 3D 创作提供了高效解决方案。

3FS

3FS

一个具备存储、管理和客户端操作等多种功能的分布式文件系统相关项目。

3FS 是一个功能强大的分布式文件系统项目,涵盖了存储引擎、元数据管理、客户端工具等多个模块。它支持多种文件操作,如创建文件和目录、设置布局等,同时具备高效的事件循环、节点选择和协程池管理等特性。适用于需要大规模数据存储和管理的场景,能够提高系统的性能和可靠性,是分布式存储领域的优质解决方案。

下拉加载更多