FastAPI中怎么实现文件上传功能

在FastAPI中实现文件上传功能非常简单。可以通过使用File类型的参数来接收上传的文件,并使用UploadFile类来处理文件。

下面是一个简单的示例代码:

from fastapi import FastAPI, File, UploadFile

app = FastAPI()

@app.post("/uploadfile/")
async def create_upload_file(file: UploadFile = File(...)):
    with open(f"uploaded_files/{file.filename}", "wb") as f:
        f.write(file.file.read())
    return {"filename": file.filename}

在上面的示例中,我们定义了一个create_upload_file路由,它接收一个file参数,类型为UploadFile,使用File装饰器。当客户端发送一个POST请求到/uploadfile/路由时,将会上传一个文件,并保存到uploaded_files目录下。

注意:

UploadFile类包含了文件的元数据,如文件名、文件大小等信息。
file.file.read()方法用于读取文件内容。
在实际应用中,需要根据具体需求对上传的文件进行验证和处理。

阅读剩余
THE END