FastAPI使用教程【更新中】

这篇博客详细介绍了FastAPI的使用,包括安装、模板创建、启动服务、访问测试、参数方法详解、静态文件存储、文件上传、接口路由、跨域请求配置、WebSocket应用以及添加中间件记录接口响应时长。通过实例代码和调用方法,帮助读者深入理解FastAPI的各项功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


一、安装命令

pip install fastapi uvicorn

二、模板

创建 main.py 文件,内容如下

from pydantic import BaseModel
from fastapi import FastAPI
from typing import Optional

# 创建服务对象
app = FastAPI()

# get --------------------------------
@app.get("/")
async def hello():
    return {
   "message": "Hello World"}
# ------------------------------------

# post ------------------------------------------------------
class Publication(BaseModel):
    title: Optional[str] = None			# 接收字符串类型,没有值就默认为None
    abstract: Optional[str] = None		# 接收字符串类型,没有值就默认为None
@app.post("/findPublication")
async def findPublication(pc: Publication):
    return {
   "message": "{}-{}".format(pc.title, pc.abstract)}
# -----------------------------------------------------------

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


三、启动命令

直接右键启动就行,或者使用如下命令启动

uvicorn main:app --host 0.0.0.0 --port 80 --reload

ps:

  1. uvicorn:是一个基于asyncio开发的一个轻量级高效的web服务器框架
  2. main:启动服务的py文件名
  3. app:服务对象名
  4. –host:ip地址
  5. –port:端口
  6. –reload:代码修改的时候自动重启服务,仅在开发时使用,上线后不要带这个参数,会降低性能

四、访问测试

1.访问服务

127.0.0.1:8000
在这里插入图片描述

2.访问API文档

  1. 127.0.0.1:8000/docs【Swagger UI 提供的api文档】
    在这里插入图片描述

  2. 127.0.0.1:8000/redoc【ReDoc 提供的api文档】
    在这里插入图片描述


五、参数方法详解

1.路径参数

<1>代码

@app.get("/items/{item_id}")
async def read_item(item_id):
    return {
   "item_id": item_id}

<2>调用方法

ip:port/items/3

2.指定数据类型的路径参数

<1>代码

@app.get("/items/{item_id}")
async def read_item(item_id: int): # 以整数类型接收
    return {
   "item_id": item_id}
@app.get("/users/{user_id}")
async def read_user(user_id: str): # 以字符串类型接收
    return {
   "user_id": user_id
评论 14
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

什么都干的派森

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值