fastapi/docs/zh/docs/tutorial/schema-extra-example.md

2.5 KiB
Raw Blame History

模式的额外信息 - 例子

您可以在JSON模式中定义额外的信息。

一个常见的用例是添加一个将在文档中显示的example

有几种方法可以声明额外的 JSON 模式信息。

Pydantic schema_extra

您可以使用 Configschema_extra 为Pydantic模型声明一个示例Pydantic 文档:定制 Schema 中所述:

{!../../../docs_src/schema_extra_example/tutorial001.py!}

这些额外的信息将按原样添加到输出的JSON模式中。

Field 的附加参数

Field, Path, Query, Body 和其他你之后将会看到的工厂函数你可以为JSON 模式声明额外信息你也可以通过给工厂函数传递其他的任意参数来给JSON 模式声明额外信息,比如增加 example:

{!../../../docs_src/schema_extra_example/tutorial002.py!}

!!! warning 请记住,传递的那些额外参数不会添加任何验证,只会添加注释,用于文档的目的。

Body 额外参数

你可以通过传递额外信息给 Field 同样的方式操作Path, Query, Body等。

比如,你可以将请求体的一个 example 传递给 Body:

{!../../../docs_src/schema_extra_example/tutorial003.py!}

文档 UI 中的例子

使用上面的任何方法,它在 /docs 中看起来都是这样的:

技术细节

关于 exampleexamples...

JSON Schema在最新的一个版本中定义了一个字段 examples ,但是 OpenAPI 基于之前的一个旧版JSON Schema并没有 examples.

所以 OpenAPI为了相似的目的定义了自己的 example (使用 example, 而不是 examples), 这也是文档 UI 所使用的 (使用 Swagger UI).

所以,虽然 example 不是JSON Schema的一部分但它是OpenAPI的一部分这将被文档UI使用。

其他信息

同样的方法你可以添加你自己的额外信息这些信息将被添加到每个模型的JSON模式中例如定制前端用户界面等等。