ホームページ > バックエンド開発 > Python チュートリアル > FastAPI POST リクエストで JSON とファイルの両方を送信するにはどうすればよいですか?

FastAPI POST リクエストで JSON とファイルの両方を送信するにはどうすればよいですか?

Barbara Streisand
リリース: 2025-01-04 17:20:39
オリジナル
656 人が閲覧しました

How to Submit Both JSON and Files in a FastAPI POST Request?

FastAPI POST リクエストにファイルと JSON 本文の両方を追加する方法?

FastAPI では、JSON データとファイルの両方を送信することはできません本文を JSON として宣言した場合は、単一のリクエストになります。代わりに、multipart/form-data エンコーディングを使用する必要があります。これを実現するためのいくつかの方法を次に示します。

方法 1: ファイルとフォームを使用する

# Assuming you have a DataConfiguration model for the JSON data
from fastapi import FastAPI, File, UploadFile
from pydantic import BaseModel

app = FastAPI()

class DataConfiguration(BaseModel):
    textColumnNames: list[str]
    idColumn: str

@app.post("/data")
async def data(dataConfiguration: DataConfiguration,
               csvFile: UploadFile = File(...)):
    pass  # read requested id and text columns from csvFile
ログイン後にコピー

方法 2: Pydantic モデルと依存関係を使用する

from fastapi import FastAPI, Form, File, UploadFile, Depends, Request
from pydantic import BaseModel
from typing import List, Optional, Dict
from fastapi.responses import HTMLResponse
from fastapi.templating import Jinja2Templates

app = FastAPI()
templates = Jinja2Templates(directory="templates")

class Base(BaseModel):
    name: str
    point: Optional[float] = None
    is_accepted: Optional[bool] = False

def validate_json_body(body: str = Form(...)):
    try:
        return Base.model_validate_json(body)
    except ValidationError as e:
        raise HTTPException(
            detail=jsonable_encoder(e.errors()),
            status_code=422,
        )

@app.post("/submit")
async def submit(base: Base = Depends(validate_json_body),
                  files: List[UploadFile] = File(...)):
    return {
        "JSON Payload": base,
        "Filenames": [file.filename for file in files],
    }

@app.get("/", response_class=HTMLResponse)
async def main(request: Request):
    return templates.TemplateResponse("index.html", {"request": request})
ログイン後にコピー

方法 3: JSON を渡す本文パラメータの文字列として

from fastapi import FastAPI, Form, UploadFile, File
from pydantic import BaseModel

class Base(BaseModel):
    name: str
    point: float
    is_accepted: bool

app = FastAPI()

@app.post("/submit")
async def submit(data: Base = Form(...), files: List[UploadFile] = File(...)):
    return {
        "JSON Payload": data,
        "Filenames": [file.filename for file in files],
    }
ログイン後にコピー

方法 4: カスタム クラスを使用して JSON を検証する

from fastapi import FastAPI, File, UploadFile, Request
from pydantic import BaseModel, model_validator
from typing import Optional, List
from fastapi.responses import HTMLResponse
from fastapi.templating import Jinja2Templates
import json

app = FastAPI()
templates = Jinja2Templates(directory="templates")

class Base(BaseModel):
    name: str
    point: Optional[float] = None
    is_accepted: Optional[bool] = False

    @model_validator(mode='before')
    @classmethod
    def validate_to_json(cls, value):
        if isinstance(value, str):
            return cls(**json.loads(value))
        return value

@app.post("/submit")
async def submit(data: Base = Body(...), files: List[UploadFile] = File(...)):
    return {
        "JSON Payload": data,
        "Filenames": [file.filename for file in files],
    }

@app.get("/", response_class=HTMLResponse)
async def main(request: Request):
    return templates.TemplateResponse("index.html", context={"request": request})
ログイン後にコピー

注:方法 1 では、Form が Body のサブクラスであるため、File クラスと Form クラスを一緒に使用できます。ただし、方法 1 で Form(...) の代わりに Body(...) を使用すると、FastAPI は JSON データがフォーム データとしてではなくリクエスト本文に含まれることを期待するため、機能しません。

以上がFastAPI POST リクエストで JSON とファイルの両方を送信するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート