6.4 KiB
메타데이터 및 문서화 URL
FastAPI 응용 프로그램에서 다양한 메타데이터 구성을 사용자 맞춤 설정할 수 있습니다.
API에 대한 메타데이터
OpenAPI 명세 및 자동화된 API 문서 UI에 사용되는 다음 필드를 설정할 수 있습니다:
매개변수 | 타입 | 설명 | ||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
title |
str |
API의 제목입니다. | ||||||||||||
summary |
str |
API에 대한 짧은 요약입니다. OpenAPI 3.1.0, FastAPI 0.99.0부터 사용 가능 | ||||||||||||
description |
str |
API에 대한 짧은 설명입니다. 마크다운을 사용할 수 있습니다. | ||||||||||||
version |
string |
API의 버전입니다. OpenAPI의 버전이 아닌, 여러분의 애플리케이션의 버전을 나타냅니다. 예: 2.5.0 |
||||||||||||
terms_of_service |
str |
API 이용 약관의 URL입니다. 제공하는 경우 URL 형식이어야 합니다. | ||||||||||||
contact |
dict |
노출된 API에 대한 연락처 정보입니다. 여러 필드를 포함할 수 있습니다.
|
매개변수 | 타입 | 설명 |
---|---|---|
name | str | 연락처 인물/조직의 식별명입니다. |
url | str | 연락처 정보가 담긴 URL입니다. URL 형식이어야 합니다. |
email | str | 연락처 인물/조직의 이메일 주소입니다. 이메일 주소 형식이어야 합니다. |
license_info
dict
license_info
필드
매개변수 | 타입 | 설명 |
---|---|---|
name | str | 필수 (license_info 가 설정된 경우). API에 사용된 라이선스 이름입니다. |
identifier | str | API에 대한 SPDX 라이선스 표현입니다. identifier 필드는 url 필드와 상호 배타적입니다. OpenAPI 3.1.0, FastAPI 0.99.0부터 사용 가능 |
url | str | API에 사용된 라이선스의 URL입니다. URL 형식이어야 합니다. |
다음과 같이 설정할 수 있습니다:
{* ../../docs_src/metadata/tutorial001.py hl[3:16,19:32] *}
/// tip
description
필드에 마크다운을 사용할 수 있으며, 출력에서 렌더링됩니다.
///
이 구성을 사용하면 문서 자동화(로 생성된) API 문서는 다음과 같이 보입니다:

라이선스 식별자
OpenAPI 3.1.0 및 FastAPI 0.99.0부터 license_info
에 identifier
를 URL 대신 설정할 수 있습니다.
예:
{* ../../docs_src/metadata/tutorial001_1.py hl[31] *}
태그에 대한 메타데이터
openapi_tags
매개변수를 사용하여 경로 작동을 그룹화하는 데 사용되는 태그에 추가 메타데이터를 추가할 수 있습니다.
리스트는 각 태그에 대해 하나의 딕셔너리를 포함해야 합니다.
각 딕셔너리에는 다음이 포함될 수 있습니다:
name
(필수):tags
매개변수에서 경로 작동과APIRouter
에 사용된 태그 이름과 동일한str
입니다.description
: 태그에 대한 간단한 설명을 담은str
입니다. 마크다운을 사용할 수 있으며 문서 UI에 표시됩니다.externalDocs
: 외부 문서를 설명하는dict
이며:description
: 외부 문서에 대한 간단한 설명을 담은str
입니다.url
(필수): 외부 문서의 URL을 담은str
입니다.
태그에 대한 메타데이터 생성
users
및 items
에 대한 태그 예시와 함께 메타데이터를 생성하고 이를 openapi_tags
매개변수로 전달해 보겠습니다:
{* ../../docs_src/metadata/tutorial004.py hl[3:16,18] *}
설명 안에 마크다운을 사용할 수 있습니다. 예를 들어 "login"은 굵게(login) 표시되고, "fancy"는 기울임꼴(fancy)로 표시됩니다.
/// tip
사용 중인 모든 태그에 메타데이터를 추가할 필요는 없습니다.
///
태그 사용
tags
매개변수를 경로 작동 및 APIRouter
와 함께 사용하여 태그에 할당할 수 있습니다:
{* ../../docs_src/metadata/tutorial004.py hl[21,26] *}
/// info
태그에 대한 자세한 내용은 경로 작동 구성{.internal-link target=_blank}에서 읽어보세요.
///
문서 확인
이제 문서를 확인하면 모든 추가 메타데이터가 표시됩니다:

태그 순서
각 태그 메타데이터 딕셔너리의 순서는 문서 UI에 표시되는 순서를 정의합니다.
예를 들어, 알파벳 순서상 users
는 items
뒤에 오지만, 우리는 users
메타데이터를 리스트의 첫 번째 딕셔너리로 추가했기 때문에 먼저 표시됩니다.
OpenAPI URL
OpenAPI 구조는 기본적으로 /openapi.json
에서 제공됩니다.
openapi_url
매개변수를 통해 이를 설정할 수 있습니다.
예를 들어, 이를 /api/v1/openapi.json
에 제공하도록 설정하려면:
{* ../../docs_src/metadata/tutorial002.py hl[3] *}
OpenAPI 구조를 완전히 비활성화하려면 openapi_url=None
으로 설정할 수 있으며, 이를 사용하여 문서화 사용자 인터페이스도 비활성화됩니다.
문서화 URL
포함된 두 가지 문서화 사용자 인터페이스를 설정할 수 있습니다:
- Swagger UI:
/docs
에서 제공됩니다.docs_url
매개변수로 URL을 설정할 수 있습니다.docs_url=None
으로 설정하여 비활성화할 수 있습니다.
- ReDoc:
/redoc
에서 제공됩니다.redoc_url
매개변수로 URL을 설정할 수 있습니다.redoc_url=None
으로 설정하여 비활성화할 수 있습니다.
예를 들어, Swagger UI를 /documentation
에서 제공하고 ReDoc을 비활성화하려면:
{* ../../docs_src/metadata/tutorial003.py hl[3] *}