FastAPI使用笔记

FastAPI使用笔记

1、依赖包

python 复制代码
aerich==0.9.0
aiofiles==24.1.0
aiomysql==0.2.0
aiosqlite==0.21.0
annotated-types==0.7.0
anyio==4.9.0
asyncclick==8.1.8.0
certifi==2025.4.26
click==8.1.8
colorama==0.4.6
dictdiffer==0.9.0
dnspython==2.7.0
email_validator==2.2.0
fastapi==0.115.12
fastapi-cli==0.0.7
h11==0.16.0
httpcore==1.0.9
httptools==0.6.4
httpx==0.28.1
idna==3.10
iso8601==2.1.0
Jinja2==3.1.6
markdown-it-py==3.0.0
MarkupSafe==3.0.2
mdurl==0.1.2
pydantic==2.11.4
pydantic_core==2.33.2
Pygments==2.19.1
PyMySQL==1.1.1
pypika-tortoise==0.6.0
python-dotenv==1.1.0
python-multipart==0.0.20
pytz==2025.2
PyYAML==6.0.2
rich==14.0.0
rich-toolkit==0.14.6
setuptools==78.1.1
shellingham==1.5.4
sniffio==1.3.1
starlette==0.46.2
tomlkit==0.13.2
tortoise-orm==0.25.0
typer==0.15.4
typing-inspection==0.4.0
typing_extensions==4.13.2
uvicorn==0.34.2
watchfiles==1.0.5
websockets==15.0.1
wheel==0.45.1

2、初级实现

python 复制代码
# 第一个fastapi程序
import uvicorn
from fastapi import FastAPI

app = FastAPI()


@app.get("/")
def read_root():
    return {"Hello": "World"}


# 启动服务
# 1. 通过命令: uvicorn filename:app_name --reload  #启动服务,并自动重新加载代码内容
# 2. 通过调试: fastapi dev filename.py   # 安装fastapi[standard]
# 3. 通过py运行: python filename.py  # 要有运行项目的代码
if __name__ == "__main__":
    uvicorn.run('main01:app', host="127.0.0.1", port=8000, reload=True)
    # uvicorn.run(app, host="127.0.0.1", port=8000)  #不让加reload

3、FastAPI路径参数

python 复制代码
# 路径参数
from fastapi import FastAPI

app = FastAPI()


@app.get("/args1/1")
def path_args1():
    return {"message": "id1"}


@app.get("/args2/{id}")
def path_args2(id):
    return {"message": id}


@app.get("/args3/{id}")
def path_args3(id):
    return {"message2": id}


@app.get("/args4/{id}/{name}")
def path_args4(id: int, name):
    return {"message": id, "name": name}


if __name__ == "__main__":
    import uvicorn
    uvicorn.run('main03:app', host="127.0.0.1", port=8000, reload=True)

4、FastAPI查询参数

python 复制代码
# 查询参数
from fastapi import FastAPI

app = FastAPI()


@app.get("/query1")
def page_limit(page, limit):
    return {"page": page, "limit": limit}


@app.get("/query2")
def page_limit2(page: int, limit=None):
    if limit:
        return {"page": page, "limit": limit}
    return {"page": page}


@app.get("/query3/{page}")
def page_limit3(page: int, limit=None):
    if limit:
        return {"page": page, "limit": limit}
    return {"page": page}


if __name__ == '__main__':
    import uvicorn
    uvicorn.run('main04:app', host="127.0.0.1", port=8000, reload=True)

5、FastAPI请求体

python 复制代码
# 请求体 传参数
from fastapi import FastAPI
from pydantic import BaseModel

app = FastAPI()


class User(BaseModel):
    name: str
    age: int
    pwd: str | None
    sex: str = "男"


@app.post('/users')
def create_user(user: dict):
    return user


@app.post('/users2')
def create_user2(user: User):
    return user


if __name__ == '__main__':
    import uvicorn
    uvicorn.run('main05:app', host="127.0.0.1", port=8000, reload=True)

6、FastAPI请求参数验证

类型验证

python 复制代码
# Python原生类型注解
from typing import Union, Optional, List
from fastapi import FastAPI

app = FastAPI()


@app.get('/items1/{item_id}')
def read_item1(item_id: int):
    return {'item_id': item_id}


@app.get('/items2/{item_id}')
def read_item2(item_id: str):
    return {'item_id': item_id}


@app.get('/items3/{item_id}')
def read_item3(item_id: Union[str, int]):
    return {'item_id': item_id}


@app.get('/items4/{item_id}')
def read_item4(item_id: Union[str, int] = 110):
    '''这个不可用默认参数'''
    return {'item_id': item_id}


@app.get('/items5')
def read_item5(item_id: Union[int, None] = None):
    return {'item_id': item_id}


@app.get('/items6')
def read_item6(item_id: Optional[int] = None):
    '''这个Optional是Union[T, None]的缩写'''
    return {'item_id': item_id}


@app.get('/items7')
def read_item7(item_ids: List):
    return {'item_id': item_ids}


# @app.get('/items8/{item_ids}')
# def read_item8(item_ids: List[int]):
#     return {'item_id': item_ids}


if __name__ == '__main__':
    import uvicorn
    uvicorn.run('main06:app', host="127.0.0.1", port=8000, reload=True)

7、FastAPI请求参数验证_Query方式

python 复制代码
# 查询参数Query
from fastapi import FastAPI, Query

app = FastAPI()


@app.get("/items1")
def read_item1(item_id: str = Query(123)):
    return {"item_id": item_id}


@app.get("/items2")
def read_item2(item_id: str = Query(...)):
    '''必须传递'''
    return {"item_id": item_id}


@app.get("/items3")
def read_item3(item_id: str = Query(..., min_length=3, max_length=6)):
    '''必须传递,限制内容长度'''
    return {"item_id": item_id}


@app.get("/items4")
def read_item4(item_id: int = Query(..., gt=0, lt=100)):
    '''必须传递,限制内容大小'''
    return {"item_id": item_id}


@app.get("/items5")
def read_item5(item_id: int = Query(..., alias='id')):
    '''必须传递,修改名称'''
    return {"item_id": item_id}


@app.get("/items6")
def read_item6(item_id: int = Query(..., description="这个字段是来筛选产品的ID")):
    '''必须传递,说明'''
    return {"item_id": item_id}


@app.get("/items7")
def read_item7(item_id: int = Query(..., deprecated=True)):
    '''必须传递,被抛弃了'''
    return {"item_id": item_id}


@app.get("/items8")
def read_item8(item_id: str = Query(..., regex='^a\d{2}$')):
    '''必须传递,通过正则匹配,pattern,regex'''
    return {"item_id": item_id}


if __name__ == '__main__':
    import uvicorn
    uvicorn.run('main07:app', host="127.0.0.1", port=8000, reload=True)
相关推荐
爱讲故事的2 小时前
计算机网络第七章:无线与移动网络复习笔记
网络·笔记·计算机网络
小陈phd2 小时前
Text2SQL智能体学习笔记(一)——NL2SQL及执行流程介绍
笔记·学习
问心无愧05132 小时前
ctf sow web入门112
android·前端·笔记
稷下元歌2 小时前
系统学习plc 基础指令上篇,官方资料课程笔记整 理
笔记·学习
放下华子我只抽RuiKe53 小时前
FastAPI 全栈后端(二):路由与数据模型
前端·人工智能·react.js·前端框架·html·fastapi
超人不会飞_Jay3 小时前
26.6.8LangChain笔记
笔记
xian_wwq3 小时前
【学习笔记】「大模型安全:攻击面演化史」第 02 篇-越狱攻防战
笔记·学习
xieliyu.4 小时前
MySQL 全套入门笔记:基础、库操作、数据类型
数据库·笔记·mysql
XGeFei4 小时前
【Fastapi学习笔记(7)】—— Fastapi 中间件、前端跨域请求
笔记·学习·fastapi