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_infodictlicense_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] *}