title: HTTP协议与RESTful API实战手册(二):用披萨店故事说透API设计奥秘

date: 2025/2/27

updated: 2025/2/27

author: cmdragon

excerpt:

本系列第二篇通过披萨店创业的完整案例,手把手教你:
用外卖订单理解HTTP协议细节
5个RESTful设计常见误区与修正方案
从零搭建支持用户/订单/库存管理的完整API
错误排查工具箱(含11种常见问题速查表)

categories:

  • 后端开发
  • FastAPI

tags:

  • HTTP实战图解
  • RESTful误区解析
  • 披萨店API案例
  • 请求响应可视化
  • 数据验证陷阱
  • FastAPI快速入门
  • 新手友好教程

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

本系列第二篇通过披萨店创业的完整案例,手把手教你:

  • 用外卖订单理解HTTP协议细节
  • 5个RESTful设计常见误区与修正方案
  • 从零搭建支持用户/订单/库存管理的完整API
  • 错误排查工具箱(含11种常见问题速查表)

第一章:HTTP协议就像披萨外卖(场景化学习)

1.1 订单生命周期对照表

外卖步骤 HTTP对应概念 示例
顾客下单 POST请求 POST /orders
打印小票 Header元数据 Content-Type: application/json
后厨制作 服务器处理逻辑 数据库写入操作
外卖异常通知 4xx/5xx状态码 404 披萨缺货

1.2 必知必会的5个状态码

@app.post("/orders")
async def create_order():
try:
# 处理订单逻辑
return JSONResponse(201, headers={"Location": "/orders/1001"})
except OutOfStock:
return JSONResponse(409, content={"error": "玛格丽特披萨库存不足"})

第二章:RESTful设计七大黄金法则

2.1 错误 vs 正确设计对比

# 错误:动词导向
@app.post("/getUserOrders")
def get_orders(): ... # 正确:名词导向
@app.get("/users/{user_id}/orders")
def get_orders(user_id: int): ...

2.2 超媒体API实战(HATEOAS)

// 订单创建响应
{
"id": 1001,
"status": "烤制中",
"_links": {
"self": {"href": "/orders/1001", "method": "GET"},
"cancel": {"href": "/orders/1001", "method": "DELETE"}
}
}

第三章:从零搭建披萨店API

3.1 完整API架构

from fastapi import FastAPI
from pydantic import BaseModel app = FastAPI() class Pizza(BaseModel):
name: str
price: float
size: Literal["S", "M", "L"] # 菜单管理
@app.get("/pizzas")
async def list_pizzas(): ... @app.post("/pizzas")
async def create_pizza(pizza: Pizza): ... # 订单系统
@app.post("/orders")
async def create_order(pizza_ids: list[int]): ...

3.2 自动化文档生成

访问 http://localhost:8000/docs 查看实时API文档:


第四章:错误处理大师课

4.1 422错误全场景复现

# 案例:忘记必填参数
@app.post("/pizzas")
async def create_pizza(pizza: Pizza):
# 如果客户端未传price字段... # 客户端收到响应:
{
"detail": [
{
"loc": ["body", "price"],
"msg": "field required",
"type": "value_error.missing"
}
]
}

4.2 错误排查流程图

graph TD
A[收到4xx错误] --> B{错误类型}
B -->|400| C[检查请求体格式]
B -->|401| D[添加认证头]
B -->|404| E[验证URL路径]
B -->|422| F[查看返回的校验详情]

第五章:安全加固与性能优化

5.1 防御披萨注入攻击

# 危险写法
def get_order(raw_id: str):
query = f"SELECT * FROM orders WHERE id = {raw_id}" # 安全写法
def get_order_safe(order_id: int):
query = "SELECT * FROM orders WHERE id = :id"
params = {"id": order_id}

5.2 缓存优化实战

from fastapi import Request
from fastapi_cache import FastAPICache
from fastapi_cache.decorator import cache @app.get("/pizzas/{pizza_id}")
@cache(expire=60) # 缓存60秒
async def get_pizza(pizza_id: int):
return db.query(Pizza).filter(Pizza.id == pizza_id).first()

课后实战工坊

任务1:扩展配送功能

# 你的挑战:
@app.get("/orders/{order_id}/tracking")
async def get_delivery_status(order_id: int):
# 返回配送状态和骑手位置
pass

任务2:设计促销系统

# 需求:
# - 创建促销活动(POST /promotions)
# - 限制每个用户参与次数
# - 过期活动自动关闭

结语

您已完成从API新手到合格开发者的蜕变。现在,用 python -m uvicorn main:app --reload 启动您的披萨店API帝国吧!


余下文章内容请点击跳转至 个人博客页面 或者 扫码关注或者微信搜一搜:编程智域 前端至全栈交流与成长,阅读完整的文章:HTTP协议与RESTful API实战手册(二):用披萨店故事说透API设计奥秘 | cmdragon's Blog

往期文章归档:

HTTP协议与RESTful API实战手册(二):用披萨店故事说透API设计奥秘 🍕的更多相关文章

  1. SDL 开发实战(二):SDL 2.0 核心 API 解析

    在上一篇文章 SDL 开发实战(一):SDL介绍及开发环境配置 中,我们配置好了SDL的开发环境,并成功运行了SDL的Hello World 代码.但是可能大部分人还是读不太明白具体Hello Wol ...

  2. Git实战手册(二): 标签应用和版本管理

    教程所示图片使用的是 github 仓库图片,墙内朋友请移步原文地址 有空就来看看个人技术小站, 我一直都在 0. 背景介绍 当一个代码仓库进过长时间的迭代,针对不同的时期和需求,必定会有不同的版本. ...

  3. ASP.NET Web API 2系列(二):灵活多样的路由配置

    1. 导言 路由系统是请求消息进入ASP.NET Web API消息处理管道的第一道屏障,其根本目的在于利用注册的路由对请求的URL进行解析以确定目标HTTPController和Action的名称, ...

  4. F5 api接口开发实战手册(二)

    F5 rest api 各对象使用方式详解 本篇文章介绍rest api接口下Collection.Resource.Subcollections.SubResource的各种使用方法.如果您不了解这 ...

  5. 使用 node-odata 轻松创建基于 OData 协议的 RESTful API

    前言 OData, 相信身为.NET程序员应该不为陌生, 对于他的实现, 之前也有童鞋进行过介绍(见:这里1,这里2). 微软的WCF Data Service即采用的该协议来进行通信, ASP.NE ...

  6. PJSUA2开发文档--第十二章 PJSUA2 API 参考手册

    12 PJSUA2 API 参考手册 12.1 endpoint.hpp PJSUA2基本代理操作.  namespace pj PJSUA2 API在pj命名空间内. 12.1.1 class En ...

  7. Spring Boot+Spring Security+JWT 实现 RESTful Api 认证(二)

    Spring Boot+Spring Security+JWT 实现 RESTful Api 认证(二) 摘要 上一篇https://javaymw.com/post/59我们已经实现了基本的登录和t ...

  8. client-go实战之二:RESTClient

    欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...

  9. RESTful 最佳实战

    在GitHub上看到一本不错的关于REST实战的书,很高兴分享阅读笔记.[下载地址] 一.什么是REST(WHAT) REST架构描述了六种约束.(统一接口.无状态.可缓存.CS架构.分层系统.按需编 ...

  10. Spring Boot 揭秘与实战(二) 数据缓存篇 - 快速入门

    文章目录 1. 声明式缓存 2. Spring Boot默认集成CacheManager 3. 默认的 ConcurrenMapCacheManager 4. 实战演练5. 扩展阅读 4.1. Mav ...

随机推荐

  1. vscode使用github

    1, vscode打开terminal,生成RSA密钥,并查看蜜月 PS D:\code\SQL> git init Reinitialized existing Git repository ...

  2. 【Amadeus原创】修改docker里面网站的port端口映射

    切记:以下顺序千万不能颠倒!否则不生效! 1. 查看需要修改的容器,记住container id docker ps -a 2. 停止容器 docker stop xxx 3. 修改容器的端口映射配置 ...

  3. 履机乘变,轻舟便楫:源启分布式PaaS深度赋能企业级技术平台建设

    导语 源启分布式PaaS平台围绕应用视角为用户提供应用运行的全生命周期管控能力,提供注册中心.服务路由.网关.服务治理等中间件技术支持,实现应用之间的联通,解决客户多厂商产品不兼容.产品组合不可选择. ...

  4. docker使用镜像报错:standard_init_linux.go:211: exec user process caused “exec format error“

    在服务器使用镜像运行代码时出现了该报错.使用了docker run 后,由于是刚接触docker,不知道是什么原因.经网上查阅资料后,了解到原来有可能是我的镜像架构和机器架构不一致. 使用 docke ...

  5. @EnableWebMvc 注解会让Swagger无效访问的问题

    在工作中,通过Swagger2对项目的controller进行配置,以便于用户测试restful服务接口提高开发效率. 但是今天却出现了一个让我匪夷所思的问题就是在配置类里面加上@EnableWebM ...

  6. Java调用Shell问题整理

    背景 java可以通过Runtime来调用其他进程,如cmd命令,shell文件或脚本等. 基本用法 Runtime执行时返回一个Process对象,利用该对象完成脚本执行.下面的例子中,Linux的 ...

  7. leetcode 05 回文字符串

    leetcode 05 回文字符串 1. 描述 给你一个字符串,找到里面最长的回文字符串 2. 事例 示例 1: 输入:s = "babad" 输出:"bab" ...

  8. Qt编写地图综合应用45-路径规划

    一.前言 路径规划一般是根据起始点坐标经纬度和结束点坐标经纬度,查询出合适的路线.关于起始坐标和结束坐标,最开始做的是直接传入具体中文地址即可,后面百度地图不再开放此功能,貌似变成了收费功能,但是经纬 ...

  9. Qt音视频开发1-vlc解码播放

    一.前言 最开始接触视频监控这块的时候,用的就是vlc作为解码的内核,主要是因为vlc使用简单方便,直接传入一个句柄即可,简单几行代码就可以实现一个视频流播放,很适合初学者使用,也推荐初学者用qt+v ...

  10. Pycharm创建工程及运行程序入门教程

    pycharm基础使用步骤 1.下载pycharm2.新建Python工程(1)如下,点击Create New Project (2)选择保存位置,点击create. (3)命名,打开界面如下 (4) ...