【超详细】Python FastAPI 入门:写给新手的“保姆级”教程

【超详细】Python FastAPI 入门:写给新手的“保姆级”教程(2025–2026 最新版)

这篇教程的目标是:
零基础 → 能独立写出生产级别的 RESTful API
预计认真跟着做完前 80%,你大概需要 3–10 天(每天 2–4 小时)。

目录(建议按顺序阅读)

  1. 为什么选择 FastAPI(而不是 Flask / Django)
  2. 环境准备(最稳的几种方式)
  3. 第一个 FastAPI 程序(Hello World)
  4. 核心概念速览(5 分钟建立大局观)
  5. 路径参数、查询参数、请求体(最常用三大输入方式)
  6. 响应模型 & 状态码
  7. 依赖注入(Dependency Injection)入门
  8. 异步 vs 同步(什么时候用 async def)
  9. 数据库连接(SQLAlchemy + asyncpg 推荐组合)
  10. 自动生成的交互式文档(Swagger & ReDoc)
  11. 错误处理 & 自定义异常
  12. 安全基础(JWT + OAuth2)
  13. 项目结构推荐(中大型项目怎么组织)
  14. 部署(Docker + gunicorn + uvicorn 最常见组合)
  15. 常见问题 & 调试技巧

1. 为什么选择 FastAPI(2025–2026 视角)

维度FastAPIFlaskDjango结论(2025–2026)
开发速度★★★★★★★★★☆★★★☆☆最快
性能接近 Node.js / Go中等中等偏下目前 Python 最快
自动文档OpenAPI + Swagger + ReDoc需手动或扩展admin 强大但 API 需额外写碾压
类型提示支持原生 Pydantic v2需插件部分支持现代开发标配
异步支持原生 async/await需 gevent 或异步扩展Channels(较重)天生异步
学习曲线(新手)中等(但文档极好)最低较高性价比最高
社区活跃度爆炸式增长成熟但增速放缓非常成熟未来 3–5 年首选

一句话结论:
如果你 2025–2026 年想用 Python 写高性能、现代、好维护的 API,FastAPI 几乎是唯一主流选择。

2. 环境准备(选一种最适合你的)

推荐组合(最稳)
Python 3.10 / 3.11 / 3.12 + uv / pdm / poetry(现代包管理) + venv

最快上手方式(5 分钟)

# 方式一:用 uv(2025 年最推荐的极简工具,速度比 pip 快 10–100 倍)curl -LsSf https://astral.sh/uv/install.sh |sh uv venv source .venv/bin/activate # Windows 用 .venv\Scripts\activate uv pip install fastapi[standard] uvicorn[standard]

备选方式(经典 pip + venv)

python -m venv venv source venv/bin/activate # Windows: venv\Scripts\activate pip install --upgrade pip pip install fastapi[standard] uvicorn[standard]

安装完成后运行下面代码测试:

# main.pyfrom fastapi import FastAPI app = FastAPI()@app.get("/")defread_root():return{"Hello":"FastAPI"}

启动:

uvicorn main:app --reload # 或 python -m uvicorn main:app --reload 

浏览器打开:http://127.0.0.1:8000
看到 JSON 就成功了!

再访问 http://127.0.0.1:8000/docs → 自动 Swagger 界面出现,恭喜你进入 FastAPI 世界!

3. 核心概念速览(5 分钟建立心智模型)

概念通俗解释代码例子简写
FastAPI()创建应用实例app = FastAPI()
@app.get/post/…路由装饰器@app.get(“/items/{item_id}”)
路径参数URL 里的动态部分item_id: int
查询参数?key=valueq: str = None
请求体POST/PUT 里的 JSONitem: Item
Pydantic BaseModel数据验证 + 序列化 + 自动文档class Item(BaseModel): …
Depends依赖注入(认证、数据库、配置等)Depends(get_current_user)
BackgroundTasks后台任务(发邮件、记录日志)background_tasks.add_task(…)

4. 经典入门案例:图书管理 API(边学边写)

我们用一个“简易图书管理系统”贯穿全文。

models.py

from pydantic import BaseModel, Field from typing import Optional classBookBase(BaseModel): title:str= Field(..., min_length=1, max_length=100) author:str= Field(..., min_length=1, max_length=50) year:int= Field(..., ge=1900, le=2100)classBookCreate(BookBase):passclassBook(BookBase):id:int is_available:bool=TrueclassConfig: from_attributes =True# 兼容 ORM

main.py(逐步添加)

from fastapi import FastAPI, HTTPException, Query, Path from typing import List from models import Book, BookCreate app = FastAPI(title="图书管理 API", version="0.1.0")# 假数据库 books_db: List[Book]=[ Book(id=1, title="Python速成", author="重阳", year=2025),]@app.get("/books/", response_model=List[Book])defget_books( skip:int= Query(0, ge=0), limit:int= Query(10, ge=1, le=100), author: Optional[str]=None): result = books_db[skip : skip + limit]if author: result =[b for b in result if b.author.lower()== author.lower()]return result @app.get("/books/{book_id}", response_model=Book)defget_book(book_id:int= Path(..., ge=1)):for book in books_db:if book.id== book_id:return book raise HTTPException(status_code=404, detail="图书不存在")@app.post("/books/", response_model=Book, status_code=201)defcreate_book(book: BookCreate): new_id =max(b.idfor b in books_db)+1if books_db else1 new_book = Book(id=new_id,**book.model_dump()) books_db.append(new_book)return new_book 

启动后就能在 Swagger 上直接测试增删改查了。

下一阶段预告(建议按顺序继续)

  • 第 5–8 节:请求体、响应模型、依赖注入、异步路由
  • 第 9–10 节:连真实数据库(PostgreSQL + SQLAlchemy 异步)
  • 第 11–13 节:认证(JWT)、项目结构、错误处理
  • 第 14–15 节:Docker 部署 + 生产化配置

你现在最想先深入哪一部分?

  1. 继续跟着上面的图书系统写数据库部分(SQLAlchemy async)
  2. 先把认证(JWT + OAuth2)补上
  3. 想看完整项目结构推荐(文件夹怎么分)
  4. 想直接看 Docker + 生产部署方案
  5. 有具体报错或想改某个功能(告诉我)

回复我,我继续陪你写下去~ 😄

Read more

Qwen3Guard-Gen-WEB功能全测评,真实场景下表现如何

Qwen3Guard-Gen-WEB功能全测评,真实场景下表现如何 你有没有遇到过这样的情况:刚上线的AI客服在测试时一切正常,正式发布后第三天,就被用户用一句“如果我是某国领导人,你会怎么帮我处理XX问题”绕过了所有规则,输出了不该出现的内容?或者,跨境电商App里一段西班牙语商品描述被误判为“政治敏感”,导致整批上架失败,运营团队连夜人工复核? 这不是模型能力不足,而是传统安全审核机制与真实交互场景之间存在一道看不见的鸿沟——它不在于算力不够,而在于理解方式不对。 Qwen3Guard-Gen-WEB 镜像,正是阿里开源的那把试图填平这道鸿沟的钥匙。它不是又一个黑盒分类API,而是一个开箱即用、带完整Web界面的安全审核专家。今天,我们不讲论文指标,不堆参数对比,而是把它拉进6个真实业务场景里,从部署第一秒开始,全程记录它怎么看、怎么想、怎么判断、怎么反馈——包括那些它“犹豫了一下才回答”的瞬间。 1. 一键部署体验:5分钟完成从镜像到可用服务 1.1 真实部署过程还原(无美化) 我们使用ZEEKLOG星图镜像广场提供的 Qwen3Guard-Gen-WEB 镜像,在

By Ne0inhk
个性化图书推荐系统信息管理系统源码-SpringBoot后端+Vue前端+MySQL【可直接运行】

个性化图书推荐系统信息管理系统源码-SpringBoot后端+Vue前端+MySQL【可直接运行】

摘要 随着数字化阅读的普及,个性化图书推荐系统在提升用户体验和满足读者需求方面发挥了重要作用。传统的图书推荐方式往往基于简单的分类或热门榜单,难以满足读者多样化的兴趣偏好。现代推荐系统通过分析用户行为数据、阅读历史和偏好,能够提供更加精准的个性化推荐。本研究旨在开发一个基于SpringBoot后端、Vue前端和MySQL数据库的个性化图书推荐系统,该系统能够通过算法分析用户行为,动态调整推荐内容,从而提升用户的阅读体验和满意度。关键词:个性化推荐、数字化阅读、用户行为分析、动态调整、阅读体验。 本研究采用SpringBoot作为后端框架,结合Vue.js前端技术,构建了一个高效、可扩展的个性化图书推荐系统。系统通过MySQL数据库存储用户数据、图书信息和推荐记录,并利用协同过滤算法和内容-based算法实现精准推荐。功能模块包括用户注册与登录、图书浏览与搜索、推荐列表生成、用户反馈收集等。系统支持管理员对图书信息进行管理,同时提供用户个人中心,方便查看阅读历史和推荐记录。后端采用RESTful API设计,前端通过Axios实现数据交互,确保系统的高效运行和良好的用户体验。关键词:

By Ne0inhk
前端流式输出实现详解:从原理到实践

前端流式输出实现详解:从原理到实践

前端流式输出实现详解:从原理到实践 * 前言 * 一、流式输出核心原理 * 1.1 什么是流式输出? * 1.2 技术优势对比 * 1.3 关键技术支撑 * 二、原生JavaScript实现方案 * 2.1 使用Fetch API流式处理 * 关键点解析: * 2.2 处理SSE(Server-Sent Events) * 三、主流框架实现示例 * 3.1 React实现方案 * 3.2 Vue实现方案 * 四、高级优化策略 * 4.1 性能优化 * 4.2 用户体验增强 * 4.3 安全注意事项 * 五、实际应用案例 * 5.1 聊天应用实现

By Ne0inhk
前端八股文面经大全:腾讯前端AI面试(2026-02-28)·面经深度解析

前端八股文面经大全:腾讯前端AI面试(2026-02-28)·面经深度解析

前言 大家好,我是木斯佳。 在这个春节假期,当大家都在谈论返乡、团圆与休息时,作为一名技术人,我的思考却不由自主地转向了行业的「冬」与「春」。 相信很多人都感受到了,在AI浪潮的席卷之下,前端领域的门槛在变高,纯粹的“增删改查”岗位正在肉眼可见地减少。曾经热闹非凡的面经分享,如今也沉寂了许多。但我们都知道,市场的潮水退去,留下的才是真正在踏实准备、努力沉淀的人。学习的需求,从未消失,只是变得更加务实和深入。 这个专栏的初衷很简单:拒绝过时的、流水线式的PDF引流贴,专注于收集和整理当下最新、最真实的前端面试资料。我会在每一份面经和八股文的基础上,尝试从面试官的角度去拆解问题背后的逻辑,而不仅仅是提供一份静态的背诵答案。无论你是校招还是社招,目标是中大厂还是新兴团队,只要是真实发生、有价值的面试经历,我都会在这个专栏里为你沉淀下来。 温馨提示:市面上的面经鱼龙混杂,甄别真伪、把握时效,是我们对抗内卷最有效的武器。 让我们一起充电,为下一个技术春天做好准备。 面经原文内容 📍面试公司:腾讯 🕐面试时间:

By Ne0inhk