committed by
GitHub
1 changed files with 97 additions and 0 deletions
@ -0,0 +1,97 @@ |
|||
# ๊ฒฝ๋ก ๋์ ์ค์ |
|||
|
|||
*๊ฒฝ๋ก ์๋ ๋ฐ์ฝ๋ ์ดํฐ*๋ฅผ ์ค์ ํ๊ธฐ ์ํด์ ์ ๋ฌํ ์ ์๋ ๋ช ๊ฐ์ง ๋งค๊ฐ๋ณ์๊ฐ ์์ต๋๋ค. |
|||
|
|||
!!! warning "๊ฒฝ๊ณ " |
|||
์๋ ๋งค๊ฐ๋ณ์๋ค์ *๊ฒฝ๋ก ์๋ ํจ์*๊ฐ ์๋ *๊ฒฝ๋ก ์๋ ๋ฐ์ฝ๋ ์ดํฐ*์ ์ง์ ์ ๋ฌ๋๋ค๋ ์ฌ์ค์ ๊ธฐ์ตํ์ญ์์ค. |
|||
|
|||
## ์๋ต ์ํ ์ฝ๋ |
|||
|
|||
*๊ฒฝ๋ก ์๋*์ ์๋ต์ ์ฌ์ฉ๋ (HTTP) `status_code`๋ฅผ ์ ์ํ ์ ์์ต๋๋ค. |
|||
|
|||
`404`์ ๊ฐ์ `int`ํ ์ฝ๋๋ฅผ ์ง์ ์ ๋ฌํ ์ ์์ต๋๋ค. |
|||
|
|||
ํ์ง๋ง ๊ฐ ์ฝ๋์ ์๋ฏธ๋ฅผ ๋ชจ๋ฅธ๋ค๋ฉด, `status`์ ์๋ ๋จ์ถ ์์๋ค์ ์ฌ์ฉํ ์ ์์ต๋๋ค: |
|||
|
|||
```Python hl_lines="3 17" |
|||
{!../../../docs_src/path_operation_configuration/tutorial001.py!} |
|||
``` |
|||
|
|||
๊ฐ ์ํ ์ฝ๋๋ค์ ์๋ต์ ์ฌ์ฉ๋๋ฉฐ, OpenAPI ์คํค๋ง์ ์ถ๊ฐ๋ฉ๋๋ค. |
|||
|
|||
!!! note "๊ธฐ์ ์ ์ธ๋ถ์ฌํญ" |
|||
๋ค์๊ณผ ๊ฐ์ด ์ํฌํธํ์
๋ ์ข์ต๋๋ค. `from starlette import status`. |
|||
|
|||
**FastAPI**๋ ๊ฐ๋ฐ์ ์ฌ๋ฌ๋ถ์ ํธ์๋ฅผ ์ํด์ `starlette.status`์ ๋์ผํ `fastapi.status`๋ฅผ ์ ๊ณตํฉ๋๋ค. ํ์ง๋ง Starlette์์ ์ง์ ์จ ๊ฒ์
๋๋ค. |
|||
|
|||
## ํ๊ทธ |
|||
|
|||
(๋ณดํต ๋จ์ผ `str`์ธ) `str`๋ก ๊ตฌ์ฑ๋ `list`์ ํจ๊ป ๋งค๊ฐ๋ณ์ `tags`๋ฅผ ์ ๋ฌํ์ฌ, `๊ฒฝ๋ก ์๋`์ ํ๊ทธ๋ฅผ ์ถ๊ฐํ ์ ์์ต๋๋ค: |
|||
|
|||
```Python hl_lines="17 22 27" |
|||
{!../../../docs_src/path_operation_configuration/tutorial002.py!} |
|||
``` |
|||
|
|||
์ ๋ฌ๋ ํ๊ทธ๋ค์ OpenAPI์ ์คํค๋ง์ ์ถ๊ฐ๋๋ฉฐ, ์๋ ๋ฌธ์ ์ธํฐํ์ด์ค์์ ์ฌ์ฉ๋ฉ๋๋ค: |
|||
|
|||
<img src="/img/tutorial/path-operation-configuration/image01.png"> |
|||
|
|||
## ์์ฝ๊ณผ ๊ธฐ์ |
|||
|
|||
`summary`์ `description`์ ์ถ๊ฐํ ์ ์์ต๋๋ค: |
|||
|
|||
```Python hl_lines="20-21" |
|||
{!../../../docs_src/path_operation_configuration/tutorial003.py!} |
|||
``` |
|||
|
|||
## ๋
์คํธ๋ง์ผ๋ก ๋ง๋ ๊ธฐ์ |
|||
|
|||
์ค๋ช
์ ๋ณดํต ๊ธธ์ด์ง๊ณ ์ฌ๋ฌ ์ค์ ๊ฑธ์ณ์๊ธฐ ๋๋ฌธ์, *๊ฒฝ๋ก ์๋* ๊ธฐ์ ์ ํจ์ <abbr title="ํจ์์์ ์๋ ์ฒซ๋ฒ์งธ ํํ์์ผ๋ก, ๋ฌธ์๋ก ์ฌ์ฉ๋ ์ฌ๋ฌ ์ค์ ๊ฑธ์น (๋ณ์์ ํ ๋น๋์ง ์์) ๋ฌธ์์ด"> ๋
์คํธ๋ง</abbr> ์ ์ ์ธํ ์ ์์ต๋๋ค, ์ด๋ฅผ **FastAPI**๊ฐ ๋
์คํธ๋ง์ผ๋ก๋ถํฐ ์ฝ์ต๋๋ค. |
|||
|
|||
<a href="https://ko.wikipedia.org/wiki/%EB%A7%88%ED%81%AC%EB%8B%A4%EC%9A%B4" class="external-link" target="_blank">๋งํฌ๋ค์ด</a> ๋ฌธ๋ฒ์ผ๋ก ๋
์คํธ๋ง์ ์์ฑํ ์ ์์ต๋๋ค, ์์ฑ๋ ๋งํฌ๋ค์ด ํ์์ ๋
์คํธ๋ง์ (๋งํฌ๋ค์ด์ ๋ค์ฌ์ฐ๊ธฐ๋ฅผ ๊ณ ๋ คํ์ฌ) ์ฌ๋ฐ๋ฅด๊ฒ ํ๋ฉด์ ์ถ๋ ฅ๋ฉ๋๋ค. |
|||
|
|||
```Python hl_lines="19-27" |
|||
{!../../../docs_src/path_operation_configuration/tutorial004.py!} |
|||
``` |
|||
|
|||
์ด๋ ๋ํํ ๋ฌธ์์์ ์ฌ์ฉ๋ฉ๋๋ค: |
|||
|
|||
<img src="/img/tutorial/path-operation-configuration/image02.png"> |
|||
|
|||
## ์๋ต ๊ธฐ์ |
|||
|
|||
`response_description` ๋งค๊ฐ๋ณ์๋ก ์๋ต์ ๊ดํ ์ค๋ช
์ ๋ช
์ํ ์ ์์ต๋๋ค: |
|||
|
|||
```Python hl_lines="21" |
|||
{!../../../docs_src/path_operation_configuration/tutorial005.py!} |
|||
``` |
|||
|
|||
!!! info "์ ๋ณด" |
|||
`response_description`์ ๊ตฌ์ฒด์ ์ผ๋ก ์๋ต์ ์ง์นญํ๋ฉฐ, `description`์ ์ผ๋ฐ์ ์ธ *๊ฒฝ๋ก ์๋*์ ์ง์นญํฉ๋๋ค. |
|||
|
|||
!!! check "ํ์ธ" |
|||
OpenAPI๋ ๊ฐ *๊ฒฝ๋ก ์๋*์ด ์๋ต์ ๊ดํ ์ค๋ช
์ ์๊ตฌํ ๊ฒ์ ๋ช
์ํฉ๋๋ค. |
|||
|
|||
๋ฐ๋ผ์, ์๋ต์ ๊ดํ ์ค๋ช
์ด ์์๊ฒฝ์ฐ, **FastAPI**๊ฐ ์๋์ผ๋ก "์ฑ๊ณต ์๋ต" ์ค ํ๋๋ฅผ ์์ฑํฉ๋๋ค. |
|||
|
|||
<img src="/img/tutorial/path-operation-configuration/image03.png"> |
|||
|
|||
## ๋จ์ผ *๊ฒฝ๋ก ์๋* ์ง์์ค๋จ |
|||
|
|||
๋จ์ผ *๊ฒฝ๋ก ์๋*์ ์์ ์ง ์๊ณ <abbr title="๊ตฌ์, ์ฌ์ฉํ์ง ์๋๊ฒ์ด ๊ถ์ฅ๋จ">์ง์์ค๋จ</abbr>์ ํด์ผํ๋ค๋ฉด, `deprecated` ๋งค๊ฐ๋ณ์๋ฅผ ์ ๋ฌํ๋ฉด ๋ฉ๋๋ค. |
|||
|
|||
```Python hl_lines="16" |
|||
{!../../../docs_src/path_operation_configuration/tutorial006.py!} |
|||
``` |
|||
|
|||
๋ํํ ๋ฌธ์์ ์ง์์ค๋จ์ด๋ผ๊ณ ํ์๋ฉ๋๋ค. |
|||
|
|||
<img src="/img/tutorial/path-operation-configuration/image04.png"> |
|||
|
|||
์ง์์ค๋จ๋ ๊ฒฝ์ฐ์ ์ง์์ค๋จ ๋์ง ์์ ๊ฒฝ์ฐ์ ๋ํ *๊ฒฝ๋ก ์๋*์ด ์ด๋ป๊ฒ ๋ณด์ด๋ ์ง ํ์ธํ์ญ์์ค. |
|||
|
|||
<img src="/img/tutorial/path-operation-configuration/image05.png"> |
|||
|
|||
## ์ ๋ฆฌ |
|||
|
|||
*๊ฒฝ๋ก ์๋ ๋ฐ์ฝ๋ ์ดํฐ*์ ๋งค๊ฐ๋ณ์(๋ค)๋ฅผ ์ ๋ฌํจ์ผ๋ก *๊ฒฝ๋ก ์๋*์ ์ค์ ํ๊ณ ๋ฉํ๋ฐ์ดํฐ๋ฅผ ์ถ๊ฐํ ์ ์์ต๋๋ค. |
Loadingโฆ
Reference in new issue