FastAPI(51)- 自定义响应之 StreamingResponse、FileResponse

FastAPI(51)- 自定义响应之 StreamingResponse、FileResponse 

 

更多自定义响应类型

 

StreamingResponse

作用

采用异步生成器或普通生成器(generator)/迭代器(iterator)流式传输响应数据

 

实际代码

from fastapi import FastAPI
from fastapi.responses import StreamingResponse

file_path = "test.mp4"
app = FastAPI()
@app.get("/")
def main():
    # 这是生成器函数。它是一个“生成器函数”,因为它里面包含了 yield 语句
    def iterfile():
        # 通过使用 with 块,确保在生成器函数完成后关闭类文件对象
        with open(file_path, "rb") as file_like:
            # yield from 告诉函数迭代名为 file_like 的东西
            # 对于迭代的每个部分,yield 的内容作为来自这个生成器函数
            yield from file_like

    return StreamingResponse(iterfile(), media_type="video/mp4")
  • 如果有一个类文件对象(例如 open() 返回的对象),可以创建一个生成器函数来迭代该类文件对象
  • 这样,不必首先在内存中读取所有内容,可以将该生成器函数传递给 StreamingResponse,然后返回它
  • 这包括许多与云存储、视频处理等交互的库

 

请求结果

返回了视频啦!

 

源码 

 

FileResponse

作用

异步流式传输文件作为响应,重点一定是异步的

 

实际代码

from fastapi import FastAPI
from fastapi.responses import FileResponse

file_path = "test.mp4"
app = FastAPI()


@app.get("/file", response_class=FileResponse)
async def main():
    return file_path

感觉这个比 StreamimgResponse 简单多了

 

请求结果

和上面 StreamingResponse 一样,也返回了视频啦!

 

源码

 

 

posted @ 2022-01-06 12:17  小学弟-  阅读(616)  评论(0编辑  收藏  举报