美文网首页python-web开发
3、fastApi-特殊的请求类型

3、fastApi-特殊的请求类型

作者: 许忠慧 | 来源:发表于2023-07-29 14:50 被阅读0次

一、Cookie 参数

from typing import Annotated, Union
from fastapi import Cookie, FastAPI

app = FastAPI()

# 传递 cookie 参数
@app.get("/")
def root(ads_id: Annotated[Union[str, None], Cookie()] = None):
    return {"ads_id": ads_id}

二、 Header参数

from typing import Annotated, Union
from fastapi import FastAPI, Header

app = FastAPI()


# 传递 header 参数
@app.get("/")
def root(ads_id: Annotated[Union[str, None], Header()] = None):
    return {"ads_id": ads_id}

三、接收表单数据请求

基础语法:

from fastapi import FastAPI, Form

app = FastAPI()


@app.post("/login/")
def login(username: str = Form(), password: str = Form()):
    return True

四、请求文件

1、基础语法:

from fastapi import FastAPI, File, UploadFile

app = FastAPI()


# 适用于小型二进制文件或数据, 会将文件存储到内存
@app.post("/files/")
def create_file(file: bytes = File()):
    return {"file_size": len(file)}


# 适用于大型文件, 存储在内存的文件超出最大上限时,FastAPI 会把文件存入磁盘
@app.post("/uploadfile/")
def create_upload_file(file: UploadFile):
    return {"filename": file.filename}

UploadFile属性:

  • filename::文件名
    -content_type:文件格式(MIME 类型 / 媒体类型)字符串(str),例如,image/jpeg
  • file:文件对象

UploadFile文件支持的async方法:

  • write(data)
  • read(size)
  • seek(offset)
    • 例如,await myfile.seek(0) 移动到文件开头
    • 执行 await myfile.read()后,需再次读取已读取内容时,这种方法特别好用
  • close()

因为上述方法都是async 方法,要搭配await使用,例如:在async 方法内,要以如下方式读取文件:
contents = await myfile.read()

在普通def 路径操作函数 内,则可以直接访问 UploadFile.file

2、可选文件上传

写法:

from fastapi import FastAPI, File, UploadFile

app = FastAPI()


@app.post("/files/")
async def create_file(file: bytes | None = File(default=None)):
    if not file:
        return {"message": "No file sent"}
    else:
        return {"file_size": len(file)}


@app.post("/uploadfile/")
async def create_upload_file(file: UploadFile | None = None):
    if not file:
        return {"message": "No upload file sent"}
    else:
        return {"filename": file.filename}

3、多文件上传

语法:

from fastapi import FastAPI, File, UploadFile
from fastapi.responses import HTMLResponse

app = FastAPI()


@app.post("/files/")
async def create_files(files: list[bytes] = File()):
    return {"file_sizes": [len(file) for file in files]}


@app.post("/uploadfiles/")
async def create_upload_files(files: list[UploadFile]):
    return {"filenames": [file.filename for file in files]}


@app.get("/")
async def main():
    content = """
<body>
<form action="/files/" enctype="multipart/form-data" method="post">
<input name="files" type="file" multiple>
<input type="submit">
</form>
<form action="/uploadfiles/" enctype="multipart/form-data" method="post">
<input name="files" type="file" multiple>
<input type="submit">
</form>
</body>
    """
    return HTMLResponse(content=content)

相关文章

  • 配置Liveness和Readiness探针

    1、Liveness 探针: 命令类型 2、Liveness 探针 : HTTP 请求类型 3、Liveness ...

  • typesafe-action 笔记

    一、创建 action1、异步请求 有三个泛型:T1:请求参数类型T2:请求成功传的数据类型T3:出现错误返回类型...

  • JavaScript 基本包装类型

    ECMAScript3提供了3个特殊的引用类型:Boolean、Number和String,方便操作基本类型。 实...

  • 12306查票模块接口协议分析

    1.抓包结果 2. 请求类型: GET请求 3. 请求url: 4. 请求参数: train_date 是要出发...

  • SpringMVC-附件上传及下载

    附件的上传的http请求体的数据格式有着特殊的要求,因此需要有特殊的方式解析这种类型的http报文。SpringM...

  • 基本包装类型

    基本包装类型 3个特殊的引用类型:Boolean、Number、String 引用类型与基本包装类型的主要区别就是...

  • 7

    ECMAScript 提供了 3 个特殊的引用类型:Boolean、Number和 String。这些类型与其他引...

  • js包装对象

    ECMAScript 提供了 3 个特殊的引用类型:Boolean、Number和 String。这些类型与其他引...

  • 基本包装类型

    ECMAScript 提供了 3 个特殊的引用类型:Boolean、Number 和 String。 基本类型值不...

  • JS之基本包装类型

    基本包装类型 为了便于操作基本类型值,ECMAScript还提供 3 个特殊的引用类型: Boolean、 Num...

网友评论

    本文标题:3、fastApi-特殊的请求类型

    本文链接:https://www.haomeiwen.com/subject/etudpdtx.html