title: FastAPI路由与请求处理全解:手把手打造用户管理系统

date: 2025/3/2

updated: 2025/3/2

author: cmdragon

excerpt:

通过咖啡店点单系统的生动案例,零基础掌握FastAPI路由核心机制。你将:
用真实场景理解@app.get/@app.post等6种HTTP方法装饰器
通过用户管理API实现完整CRUD操作
学习路径参数与查询参数的进阶玩法
获得防误操作锦囊(含参数校验/SQL注入防御方案)

categories:

  • 后端开发
  • FastAPI

tags:

  • FastAPI路由实战
  • HTTP方法详解
  • 路径参数技巧
  • 查询参数进阶
  • 用户管理API
  • 请求处理陷阱
  • 新手友好教程



扫描二维码关注或者微信搜一搜:编程智域 前端至全栈交流与成长

探索数千个预构建的 AI 应用,开启你的下一个伟大创意

通过咖啡店点单系统的生动案例,零基础掌握FastAPI路由核心机制。你将:

  • 用真实场景理解@app.get/@app.post6种HTTP方法装饰器
  • 通过用户管理API实现完整CRUD操作
  • 学习路径参数查询参数的进阶玩法
  • 获得防误操作锦囊(含参数校验/SQL注入防御方案)

第一章:路由就像咖啡店电话转接

1.1 基础路由结构

from fastapi import FastAPI

app = FastAPI()

# 简单GET路由
@app.get("/menu")
async def get_menu():
return {"饮品": ["美式", "拿铁", "卡布奇诺"]} # 带路径参数的GET路由
@app.get("/orders/{order_id}")
async def get_order(order_id: int):
return {"订单号": order_id, "状态": "制作中"}

1.2 HTTP方法对照表

方法 咖啡店比喻 FastAPI装饰器
GET 查看菜单 @app.get
POST 下单新订单 @app.post
PUT 修改订单 @app.put
DELETE 取消订单 app.delete

第二章:用户管理API实战

2.1 完整CRUD实现

from typing import List
from pydantic import BaseModel class User(BaseModel):
id: int
name: str
email: str fake_db: List[User] = [] # 创建用户
@app.post("/users")
async def create_user(user: User):
fake_db.append(user)
return {"操作": "创建成功", "数据": user} # 获取所有用户
@app.get("/users")
async def get_users():
return fake_db # 更新用户
@app.put("/users/{user_id}")
async def update_user(user_id: int, new_user: User):
for index, user in enumerate(fake_db):
if user.id == user_id:
fake_db[index] = new_user
return {"操作": "更新成功"}
return {"错误": "用户不存在"} # 删除用户
@app.delete("/users/{user_id}")
async def delete_user(user_id: int):
global fake_db
fake_db = [user for user in fake_db if user.id != user_id]
return {"操作": "删除成功"}

2.2 Swagger UI自动文档

访问 http://localhost:8000/docs 查看效果:


第三章:参数处理黑科技

3.1 路径参数 vs 查询参数

# 路径参数
@app.get("/products/{category}")
async def get_by_category(category: str):
... # 查询参数
@app.get("/search")
async def search_products(keyword: str, limit: int = 10):
...

3.2 参数校验技巧

from fastapi import Query

@app.get("/users")
async def filter_users(
age: int = Query(..., ge=18, description="最小年龄"),
is_vip: bool = Query(False)
):
return [u for u in fake_db if u.age >= age and u.is_vip == is_vip]

第四章:课后安全实验室

任务1:修复SQL注入漏洞

# 危险代码
@app.get("/user/{name}")
async def get_user(name: str):
query = f"SELECT * FROM users WHERE name = '{name}'" # 你的任务:使用参数化查询改写

任务2:添加分页功能

@app.get("/users")
async def get_users(
page: int = Query(1, ge=1),
size: int = Query(10, le=100)
):
# 实现分页逻辑
start = (page - 1) * size
return fake_db[start:start + size]

常见错误诊疗室

错误现象 原因 解决方案
422 Validation Error 参数类型不匹配 检查路径参数是否为int/查询参数是否必填
405 Method Not Allowed 使用错误的HTTP方法 确认路由装饰器与方法匹配
路由冲突 多个路由相同路径 确保路径+方法组合唯一

结语

现在运行 uvicorn main:app --reload 启动你的用户管理API吧!遇到问题随时查阅附带的路由调试检查清单,编码愉快!


余下文章内容请点击跳转至 个人博客页面 或者 扫码关注或者微信搜一搜:编程智域 前端至全栈交流与成长,阅读完整的文章:FastAPI路由与请求处理全解:手把手打造用户管理系统 | cmdragon's Blog

往期文章归档:

FastAPI路由与请求处理全解:手把手打造用户管理系统 🔌的更多相关文章

  1. TCP协议要点和难点全解

    转载自http://www.cnblogs.com/leetieniu2014/p/5771324.html TCP协议要点和难点全解 说明: 1).本文以TCP的发展历程解析容易引起混淆,误会的方方 ...

  2. Mybatis系列全解(六):Mybatis最硬核的API你知道几个?

    封面:洛小汐 作者:潘潘 2020 年的大疫情,把世界撕成几片. 时至今日,依旧人心惶惶. 很庆幸,身处这安稳国, 兼得一份安稳工. · 东家常讲的一个词:深秋心态 . 大势时,不跟风.起哄, 萧条时 ...

  3. redis全解

    Redis全解 1.什么是Redis? Redis本质上是一个Key-Value类型的内存数据库,很像memcached,整个数据库统统加载在内存当中进行操作,定期通过异步操作把数据库数据flush到 ...

  4. 易全解token获取

    //易全解app             string strClientID = "2016061711434943493606";             string str ...

  5. IOS-UITextField-全解

    IOS-UITextField-全解   //初始化textfield并设置位置及大小   UITextField *text = [[UITextField alloc]initWithFrame: ...

  6. 什么是JavaScript闭包终极全解之一——基础概念

    本文转自:http://www.cnblogs.com/richaaaard/p/4755021.html 什么是JavaScript闭包终极全解之一——基础概念 “闭包是JavaScript的一大谜 ...

  7. Sql Server函数全解<五>之系统函数

    原文:Sql Server函数全解<五>之系统函数  系统信息包括当前使用的数据库名称,主机名,系统错误消息以及用户名称等内容.使用SQL SERVER中的系统函数可以在需要的时候获取这些 ...

  8. Sql Server函数全解<四>日期和时间函数

    原文:Sql Server函数全解<四>日期和时间函数   日期和时间函数主要用来处理日期和时间值,本篇主要介绍各种日期和时间函数的功能和用法,一般的日期函数除了使用date类型的参数外, ...

  9. 九度oj题目&amp;吉大考研11年机试题全解

    九度oj题目(吉大考研11年机试题全解) 吉大考研机试2011年题目: 题目一(jobdu1105:字符串的反码).    http://ac.jobdu.com/problem.php?pid=11 ...

  10. js系列教程2-对象、构造函数、对象属性全解

    全栈工程师开发手册 (作者:栾鹏) 快捷链接: js系列教程1-数组操作全解 js系列教程2-对象和属性全解 js系列教程3-字符串和正则全解 js系列教程4-函数与参数全解 js系列教程5-容器和算 ...

随机推荐

  1. mysql将公司数据随机挂在部门身上

    1.创建示例数据 CREATE TABLE department_table ( company_code VARCHAR(10) COMMENT '公司编码', company_name VARCH ...

  2. 关于在Rocky linux下安装dotnet sdk不成功的问题

    Rocky Linux 9,运行 dnf install -y dotnet-sdk-6.0 一切正常,运行起来非常顺利,安装完毕.但是非常诡异,运行 dotnet --list-sdks dotne ...

  3. java double转string去除科学计数法"E" 非tostring()和valueOf()

    在遇到需要将double类型转换string类型时,会出现转成科学计数法的形式,希望字符串能原样输出.直接使用会报java.lang.Double cannot be cast to java.lan ...

  4. 虚拟机搭建FISCO BCOS的区块链浏览器

    一键搭建 注:根据官方文档搭建,大部分与官方文档相似.我自己修改了部分代码,并对部分报错进行了解决这次使用的是一键搭建,适合前后端同机部署,快速体验的情况使用 具体安装步骤 依赖环境 环境 版本 Ja ...

  5. Qt开源作品27-鼠标定位十字线

    一.前言 上次有个群友在咨询这个问题,如何用Qt绘制一个鼠标定位的十字线,花了两分钟整了个,最没有含金量的一个demo,就是用drawline绘制了两条线,这个效果在经典的CAD软件中很常用,还有一些 ...

  6. 张正友的相机标定论文Flexible camera calibration by viewing a plane from unknown orientations的翻译

    张正友的相机标定论文Flexible camera calibration by viewing a plane from unknown orientations的翻译: 翻译的pdf版本为:htt ...

  7. springboot的Web项目编译运行时提示错误:Field userService in com.cetc.UserManger.controller.UserController required a bean of type 'com.cetc.UserManger.service.UserService' that could not be found.

    错误描述: springboot的Web项目编译运行时提示错误:Field userService in com.cetc.UserManger.controller.UserController r ...

  8. 在VS Code中vue引入新版vue-awesome-swiper编译时提示swiper/dist/css/swiper.css无法导入的问题

    在安装vue-awesome-swiper时报错swiper/dist/css/swiper.min.css找不到,如下如: 有的回答安装6.0版本的话需要引入另外一个css import 'swip ...

  9. PS2021、色环插件Coolorus下载+色环无法拖动问题和没有压感问题的解决

    PS2021+色环插件Coolorus+色环无法拖动问题解决+没有压感问题解决 1.资源下载链接 PS各版本下载: 感谢微博@vposy大佬无私奉献提供的各版本ADOBE软件直装破解: 百度网盘: p ...

  10. 数字世界中的纸张——理解 PDF (转载)

    转载自 https://type.cyhsu.xyz/2018/09/understanding-pdf-the-digitalized-paper/ 引言 PDF 是我们打交道最多的文件格式之一.提 ...