0

0

FastAPI 实现文件上传与数据传递

DDD

DDD

发布时间:2025-08-01 20:02:10

|

901人浏览过

|

来源于php中文网

原创

fastapi 实现文件上传与数据传递

本文介绍了如何在 FastAPI 框架中实现文件上传,并同时接收其他数据。通过结合 UploadFile 类型和请求参数,可以轻松构建支持文件上传和数据传递的 API 接口,解决在处理复杂业务场景时,需要同时上传文件和传递相关元数据的需求。

FastAPI 提供了强大的文件上传功能,结合请求参数,可以方便地实现文件上传和数据传递。以下是如何在 FastAPI 中实现这一功能的详细步骤和示例。

实现方法

FastAPI 使用 UploadFile 类型来处理文件上传。你可以将 UploadFile 作为函数参数,并结合其他参数来接收额外的数据。

示例代码

jQuery+echarts上传图片生成文字标签云代码
jQuery+echarts上传图片生成文字标签云代码

一款很稀有的jQuery+echarts上传图片生成文字标签云代码,基于echarts图表插件和jQuery实现根据图片样式生成彩色文字标签云特效,点击标签关键词还可以放大。

下载
from fastapi import FastAPI, UploadFile, File

app = FastAPI()


@app.post("/upload")
async def upload_file(
    file: UploadFile = File(...), transaction_id: str = None, organization_id: str = None
):
    """
    上传文件并接收 transaction_id 和 organization_id。
    """
    file_name = f"{organization_id}_{transaction_id}_{file.filename}"  # 拼接文件名,包含原始文件名
    try:
        contents = await file.read() # 使用 await 读取文件内容
        with open(file_name, "wb") as f:
            f.write(contents)
    except Exception as e:
        return {"message": f"There was an error uploading the file: {e}"}
    finally:
        await file.close() # 使用 await 关闭文件

    return {"filename": file_name, "message": "File uploaded successfully"}

代码解释

  1. 导入必要的模块: 导入 FastAPI, UploadFile 和 File。File 用于显式声明参数为文件上传。
  2. 定义路由: 使用 @app.post("/upload") 定义一个 POST 请求的路由。
  3. 定义函数参数:
    • file: UploadFile = File(...): 声明 file 参数为 UploadFile 类型,File(...) 表示这是一个文件上传字段,且为必填项。省略号 ... 表示该参数是必需的。
    • transaction_id: str = None: 声明 transaction_id 参数为字符串类型,默认为 None。
    • organization_id: str = None: 声明 organization_id 参数为字符串类型,默认为 None。
  4. 读取文件内容: 使用 await file.read() 异步读取上传文件的内容。 file.file.read() 已经被弃用,推荐使用 await file.read()。
  5. 保存文件: 使用 open(file_name, "wb") 打开一个文件,并将读取到的文件内容写入。wb 模式表示以二进制写入模式打开文件。
  6. 关闭文件: 使用 await file.close() 异步关闭文件。 确保文件资源被正确释放。
  7. 返回结果: 返回一个包含文件名和成功消息的 JSON 响应。

注意事项

  • 文件大小限制: FastAPI 默认没有文件大小限制。如果需要限制文件大小,可以使用中间件或者在路由函数中进行检查。
  • 文件类型验证: 可以根据 file.content_type 属性来验证文件类型,确保上传的文件符合预期。
  • 异常处理: 在处理文件上传时,需要考虑各种异常情况,例如文件读取失败、文件写入失败等。可以使用 try...except 块来捕获并处理这些异常。
  • 异步操作: 文件上传通常是 I/O 密集型操作,建议使用异步函数来处理,以避免阻塞主线程。
  • 文件名安全: 上面的示例直接使用了用户上传的文件名,存在安全风险。在实际应用中,应该对文件名进行处理,例如生成唯一的文件名,以防止恶意用户上传包含恶意代码的文件。
  • 使用 await 关键字: 在读取和关闭文件时,使用了 await 关键字,这是因为 file.read() 和 file.close() 是异步函数,需要使用 await 来等待它们完成。

总结

通过结合 UploadFile 类型和请求参数,可以轻松实现 FastAPI 中的文件上传和数据传递。在实际应用中,需要注意文件大小限制、文件类型验证、异常处理和文件名安全等问题。使用异步函数可以提高应用的性能。

相关专题

更多
什么是中间件
什么是中间件

中间件是一种软件组件,充当不兼容组件之间的桥梁,提供额外服务,例如集成异构系统、提供常用服务、提高应用程序性能,以及简化应用程序开发。想了解更多中间件的相关内容,可以阅读本专题下面的文章。

177

2024.05.11

Golang 中间件开发与微服务架构
Golang 中间件开发与微服务架构

本专题系统讲解 Golang 在微服务架构中的中间件开发,包括日志处理、限流与熔断、认证与授权、服务监控、API 网关设计等常见中间件功能的实现。通过实战项目,帮助开发者理解如何使用 Go 编写高效、可扩展的中间件组件,并在微服务环境中进行灵活部署与管理。

212

2025.12.18

json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

411

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

532

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

309

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

74

2025.09.10

Python FastAPI异步API开发_Python怎么用FastAPI构建异步API
Python FastAPI异步API开发_Python怎么用FastAPI构建异步API

Python FastAPI 异步开发利用 async/await 关键字,通过定义异步视图函数、使用异步数据库库 (如 databases)、异步 HTTP 客户端 (如 httpx),并结合后台任务队列(如 Celery)和异步依赖项,实现高效的 I/O 密集型 API,显著提升吞吐量和响应速度,尤其适用于处理数据库查询、网络请求等耗时操作,无需阻塞主线程。

26

2025.12.22

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

254

2023.08.03

php与html混编教程大全
php与html混编教程大全

本专题整合了php和html混编相关教程,阅读专题下面的文章了解更多详细内容。

11

2026.01.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
10分钟--Midjourney创作自己的漫画
10分钟--Midjourney创作自己的漫画

共1课时 | 0.1万人学习

Midjourney 关键词系列整合
Midjourney 关键词系列整合

共13课时 | 0.9万人学习

AI绘画教程
AI绘画教程

共2课时 | 0.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号