1
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

【Laravel】L5-Swaggerでファイルを含むリクエストボディを定義する

Last updated at Posted at 2023-08-15

目的

L5-Swaggerは、LaravelのOpenAPI(Swagger)の仕様書を記述するためのライブラリです。
リクエストボディにファイルを含む場合のSwagger-PHPの記述方法を備忘録として残します。

実行環境

  • Laravel 10
  • OpenAPI 3.1.0

記述方法

下記の例のように@OA\MediaTypeを指定する必要があります。
参考: File Upload (Swagger)
ファイルの場合、プロパティのtypeはstring、formatはbinaryです。

    /**
     * @OA\Post(
     *     path="/api/image",
     *     summary="画像をアップロードする",
     *     @OA\RequestBody(
     *         @OA\MediaType(
     *             mediaType="multipart/form-data",
     *             @OA\Property(
     *                 property="image",
     *                 type="string",
     *                 format="binary"
     *             )
     *         )
     *     )
     * )
     */

これは、次のyamlの定義に相当します。

paths:
  /api/image:
    post:
      summary: 画像をアップロードする
      requestBody:
        content:
          multipart/form-data:
            schema:
              type: object
              properties:
                image:
                  type: string
                  format: binary

Swagger UIでも、ファイルのアップロードを検証することができます。

スクリーンショット 2023-08-15 17.33.00.png

1
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
1
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?