@ -1,12 +1,8 @@
{!../../../docs/missing-translation.md!}
< p align = "center" >
< a href = "https://fastapi.tiangolo.com" > < img src = "https://fastapi.tiangolo.com/img/logo-margin/logo-teal.png" alt = "FastAPI" > < / a >
< / p >
< p align = "center" >
< em > FastAPI framework, high performance, easy to learn, fast to code, ready for production < / em >
< em > FastAPI ํ๋ ์์ํฌ, ๊ณ ์ฑ๋ฅ, ๊ฐํธํ ํ์ต, ๋น ๋ฅธ ์ฝ๋ ์์ฑ, ์ค๋น๋ ํ๋ก๋์
< / em >
< / p >
< p align = "center" >
< a href = "https://github.com/tiangolo/fastapi/actions?query=workflow%3ATest" target = "_blank" >
@ -22,29 +18,29 @@
---
**Documentation **: < a href = "https://fastapi.tiangolo.com" target = "_blank" > https://fastapi.tiangolo.com< / a >
**๋ฌธ์ **: < a href = "https://fastapi.tiangolo.com" target = "_blank" > https://fastapi.tiangolo.com< / a >
**Source Code **: < a href = "https://github.com/tiangolo/fastapi" target = "_blank" > https://github.com/tiangolo/fastapi< / a >
**์์ค ์ฝ๋ **: < a href = "https://github.com/tiangolo/fastapi" target = "_blank" > https://github.com/tiangolo/fastapi< / a >
---
FastAPI is a modern, fast (high-performance), web framework for building APIs with Python 3.6+ based on standard Python type hints .
FastAPI๋ ํ๋์ ์ด๊ณ , ๋น ๋ฅด๋ฉฐ(๊ณ ์ฑ๋ฅ), ํ์ด์ฌ ํ์ค ํ์
ํํธ์ ๊ธฐ์ดํ Python3.6+์ API๋ฅผ ๋น๋ํ๊ธฐ ์ํ ์น ํ๋ ์์ํฌ์
๋๋ค .
The key features are :
์ฃผ์ ํน์ง์ผ๋ก :
* **Fast** : Very high performance, on par with **NodeJS** and **Go** (thanks to Starlette and Pydantic). [One of the fastest Python frameworks available ](#performance ).
* **๋น ๋ฆ** : (Starlette๊ณผ Pydantic ๋๋ถ์) **NodeJS** ๋ฐ **Go**์ ๋๋ฑํ ์ ๋๋ก ๋งค์ฐ ๋์ ์ฑ๋ฅ. [์ฌ์ฉ ๊ฐ๋ฅํ ๊ฐ์ฅ ๋น ๋ฅธ ํ์ด์ฌ ํ๋ ์์ํฌ ์ค ํ๋ ](#performance ).
* **Fast to code** : Increase the speed to develop features by about 200% to 300% . *
* **Fewer bugs** : Reduce about 40% of human (developer) induced errors . *
* **Intuitive** : Great editor support. < abbr title = "also known as auto-complete, autocompletion, IntelliSense" > Completion</ abbr > everywhere. Less time debugging .
* **Easy** : Designed to be easy to use and learn. Less time reading docs .
* **Short** : Minimize code duplication. Multiple features from each parameter declaration. Fewer bugs .
* **Robust** : Get production-ready code. With automatic interactive documentation .
* **Standards-based** : Based on (and fully compatible with) the open standards for APIs : < a href = "https://github.com/OAI/OpenAPI-Specification" class = "external-link" target = "_blank" > OpenAPI</ a > (previously known as Swagger) and < a href = "http://json-schema.org/" class = "external-link" target = "_blank" > JSON Schema </ a > .
* **๋น ๋ฅธ ์ฝ๋ ์์ฑ** : ์ฝ 200%์์ 300%๊น์ง ๊ธฐ๋ฅ ๊ฐ๋ฐ ์๋ ์ฆ๊ฐ . *
* **์ ์ ๋ฒ๊ทธ** : ์ฌ๋(๊ฐ๋ฐ์)์ ์ํ ์๋ฌ ์ฝ 40% ๊ฐ์ . *
* **์ง๊ด์ ** : ํ๋ฅญํ ํธ์ง๊ธฐ ์ง์. ๋ชจ๋ ๊ณณ์์ < abbr title = "also known as auto-complete, autocompletion, IntelliSense" > ์๋์์ฑ</ abbr > . ์ ์ ๋๋ฒ๊น
์๊ฐ .
* **์ฌ์** : ์ฝ๊ฒ ์ฌ์ฉํ๊ณ ๋ฐฐ์ฐ๋๋ก ์ค๊ณ. ์ ์ ๋ฌธ์ ์ฝ๊ธฐ ์๊ฐ .
* **์งง์** : ์ฝ๋ ์ค๋ณต ์ต์ํ. ๊ฐ ๋งค๊ฐ๋ณ์ ์ ์ธ์ ์ฌ๋ฌ ๊ธฐ๋ฅ. ์ ์ ๋ฒ๊ทธ .
* **๊ฒฌ๊ณ ํจ** : ์ค๋น๋ ํ๋ก๋์
์ฉ ์ฝ๋๋ฅผ ์ป์ผ์ธ์. ์๋ ๋ํํ ๋ฌธ์์ ํจ๊ป .
* **ํ์ค ๊ธฐ๋ฐ** : API์ ๋ํ (์์ ํ ํธํ๋๋) ๊ฐ๋ฐฉํ ํ์ค ๊ธฐ๋ฐ : < a href = "https://github.com/OAI/OpenAPI-Specification" class = "external-link" target = "_blank" > OpenAPI</ a > (์ด์ ์ Swagger๋ก ์๋ ค์ก๋) ๋ฐ < a href = "http://json-schema.org/" class = "external-link" target = "_blank" > JSON ์คํค๋ง </ a > .
< small > * estimation based on tests on an internal development team, building production applications. < / small >
< small > * ๋ด๋ถ ๊ฐ๋ฐํ์ ํ๋ก๋์
์ ํ๋ฆฌ์ผ์ด์
์ ๋น๋ํ ํ
์คํธ์ ๊ทผ๊ฑฐํ ์ธก์ < / small >
## Gold Sponsors
## ๊ณจ๋ ์คํฐ์
<!-- sponsors -->
@ -56,66 +52,66 @@ The key features are:
<!-- /sponsors -->
< a href = "https://fastapi.tiangolo.com/fastapi-people/#sponsors" class = "external-link" target = "_blank" > Other sponsors < / a >
< a href = "https://fastapi.tiangolo.com/fastapi-people/#sponsors" class = "external-link" target = "_blank" > ๋ค๋ฅธ ์คํฐ์ < / a >
## Opinions
## ์๊ฒฌ๋ค
"_[...] I'm using **FastAPI** a ton these days. [...] I'm actually planning to use it for all of my team's **ML services at Microsoft** . Some of them are getting integrated into the core **Windows** product and some **Office** products ._"
"_[...] ์ ๋ ์์ฆ **FastAPI**๋ฅผ ๋ง์ด ์ฌ์ฉํ๊ณ ์์ต๋๋ค. [...] ์ฌ์ค ์ฐ๋ฆฌ ํ์ **๋ง์ดํฌ๋ก์ํํธ ML ์๋น์ค** ์ ๋ถ๋ฅผ ๋ฐ๊ฟ ๊ณํ์
๋๋ค. ๊ทธ์ค ์ผ๋ถ๋ ํต์ฌ **Windows**์ ๋ช๋ช์ **Office** ์ ํ๋ค์ด ํตํฉ๋๊ณ ์์ต๋๋ค ._"
< div style = "text-align: right; margin-right: 10%;" > Kabir Khan - < strong > Microsoft < / strong > < a href = "https://github.com/tiangolo/fastapi/pull/26" target = "_blank" > < small > (ref)< / small > < / a > < / div >
< div style = "text-align: right; margin-right: 10%;" > Kabir Khan - < strong > ๋ง์ดํฌ๋ก์ํํธ < / strong > < a href = "https://github.com/tiangolo/fastapi/pull/26" target = "_blank" > < small > (ref)< / small > < / a > < / div >
---
"_We adopted the **FastAPI** library to spawn a **REST** server that can be queried to obtain **predictions** . [for Ludwig ]_"
"_**FastAPI** ๋ผ์ด๋ธ๋ฌ๋ฆฌ๋ฅผ ์ฑํํ์ฌ **์์ธก**์ ์ป๊ธฐ ์ํด ์ฟผ๋ฆฌ๋ฅผ ์คํ ํ ์ ์๋ **REST** ์๋ฒ๋ฅผ ์์ฑํ์ต๋๋ค. [Ludwig์ ์ํด ]_"
< div style = "text-align: right; margin-right: 10%;" > Piero Molino, Yaroslav Dudin, and Sai Sumanth Miryala - < strong > Uber < / strong > < a href = "https://eng.uber.com/ludwig-v0-2/" target = "_blank" > < small > (ref)< / small > < / a > < / div >
< div style = "text-align: right; margin-right: 10%;" > Piero Molino, Yaroslav Dudin ๊ทธ๋ฆฌ๊ณ Sai Sumanth Miryala - < strong > ์ฐ๋ฒ < / strong > < a href = "https://eng.uber.com/ludwig-v0-2/" target = "_blank" > < small > (ref)< / small > < / a > < / div >
---
"_**Netflix** is pleased to announce the open-source release of our **crisis management** orchestration framework: **Dispatch** ! [built with **FastAPI** ]_"
"_**Netflix**๋ ์ฐ๋ฆฌ์ ์คํ ์์ค ๋ฐฐํฌํ์ธ **์๊ธฐ ๊ด๋ฆฌ** ์ค์ผ์คํธ๋ ์ด์
ํ๋ ์์ํฌ๋ฅผ ๋ฐํํ ์ ์์ด ๊ธฐ์ฉ๋๋ค: ๋ฐ๋ก **Dispatch**์
๋๋ค! [**FastAPI**๋ก ๋น๋ ]_"
< div style = "text-align: right; margin-right: 10%;" > Kevin Glisson, Marc Vilanova, Forest Monsen - < strong > Netflix < / strong > < a href = "https://netflixtechblog.com/introducing-dispatch-da4b8a2a8072" target = "_blank" > < small > (ref)< / small > < / a > < / div >
< div style = "text-align: right; margin-right: 10%;" > Kevin Glisson, Marc Vilanova, Forest Monsen - < strong > ๋ทํ๋ฆญ์ค < / strong > < a href = "https://netflixtechblog.com/introducing-dispatch-da4b8a2a8072" target = "_blank" > < small > (ref)< / small > < / a > < / div >
---
"_Iโm over the moon excited about **FastAPI** . Itโs so fun !_"
"_**FastAPI**๊ฐ ๋๋ฌด ์ข์์ ๊ตฌ๋ฆ ์๋ฅผ ๊ฑท๋๋ฏ ํฉ๋๋ค. ์ ๋ง ์ฆ๊ฒ์ต๋๋ค !_"
< div style = "text-align: right; margin-right: 10%;" > Brian Okken - < strong > < a href = "https://pythonbytes.fm/episodes/show/123/time-to-right-the-py-wrongs?time_in_sec=855" target = "_blank" > Python Bytes< / a > podcast host < / strong > < a href = "https://twitter.com/brianokken/status/1112220079972728832" target = "_blank" > < small > (ref)< / small > < / a > < / div >
< div style = "text-align: right; margin-right: 10%;" > Brian Okken - < strong > < a href = "https://pythonbytes.fm/episodes/show/123/time-to-right-the-py-wrongs?time_in_sec=855" target = "_blank" > Python Bytes< / a > ํ์บ์คํธ ํธ์คํธ < / strong > < a href = "https://twitter.com/brianokken/status/1112220079972728832" target = "_blank" > < small > (ref)< / small > < / a > < / div >
---
"_Honestly, what you've built looks super solid and polished. In many ways, it's what I wanted **Hug** to be - it's really inspiring to see someone build that ._"
"_์์งํ, ๋น์ ์ด ๋ง๋ ๊ฒ์ ๋งค์ฐ ๊ฒฌ๊ณ ํ๊ณ ์ธ๋ จ๋์ด ๋ณด์
๋๋ค. ์ฌ๋ฌ ๋ฉด์์ **Hug**๊ฐ ์ด๋ ๊ฒ ๋์์ผ๋ฉด ํฉ๋๋ค - ๊ทธ๊ฑธ ๋ง๋ ๋๊ตฐ๊ฐ๋ฅผ ๋ณด๋ ๊ฒ์ ๋ง์ ์๊ฐ์ ์ค๋๋ค ._"
< div style = "text-align: right; margin-right: 10%;" > Timothy Crosley - < strong > < a href = "http://www.hug.rest/" target = "_blank" > Hug< / a > creator < / strong > < a href = "https://news.ycombinator.com/item?id=19455465" target = "_blank" > < small > (ref)< / small > < / a > < / div >
< div style = "text-align: right; margin-right: 10%;" > Timothy Crosley - < strong > < a href = "http://www.hug.rest/" target = "_blank" > Hug< / a > ์ ์์ < / strong > < a href = "https://news.ycombinator.com/item?id=19455465" target = "_blank" > < small > (ref)< / small > < / a > < / div >
---
"_If you're looking to learn one **modern framework** for building REST APIs, check out **FastAPI** [...] It's fast, easy to use and easy to learn [...]_"
"_REST API๋ฅผ ๋ง๋ค๊ธฐ ์ํด **ํ๋์ ์ธ ํ๋ ์์ํฌ**๋ฅผ ์ฐพ๊ณ ์๋ค๋ฉด **FastAPI**๋ฅผ ํ์ธํด ๋ณด์ธ์. [...] ๋น ๋ฅด๊ณ , ์ฐ๊ธฐ ์ฝ๊ณ , ๋ฐฐ์ฐ๊ธฐ๋ ์ฝ์ต๋๋ค [...]_"
"_We've switched over to **FastAPI** for our **APIs** [...] I think you'll like it [...]_"
"_์ฐ๋ฆฌ **API**๋ฅผ **FastAPI**๋ก ๋ฐ๊ฟจ์ต๋๋ค [...] ์๋ง ์ฌ๋ฌ๋ถ๋ ์ข์ํ์ค ๊ฒ๋๋ค [...]_"
< div style = "text-align: right; margin-right: 10%;" > Ines Montani - Matthew Honnibal - < strong > < a href = "https://explosion.ai" target = "_blank" > Explosion AI< / a > founders - < a href = "https://spacy.io" target = "_blank" > spaCy< / a > creators < / strong > < a href = "https://twitter.com/_inesmontani/status/1144173225322143744" target = "_blank" > < small > (ref)< / small > < / a > - < a href = "https://twitter.com/honnibal/status/1144031421859655680" target = "_blank" > < small > (ref)< / small > < / a > < / div >
< div style = "text-align: right; margin-right: 10%;" > Ines Montani - Matthew Honnibal - < strong > < a href = "https://explosion.ai" target = "_blank" > Explosion AI< / a > ์ค๋ฆฝ์ - < a href = "https://spacy.io" target = "_blank" > spaCy< / a > ์ ์์ < / strong > < a href = "https://twitter.com/_inesmontani/status/1144173225322143744" target = "_blank" > < small > (ref)< / small > < / a > - < a href = "https://twitter.com/honnibal/status/1144031421859655680" target = "_blank" > < small > (ref)< / small > < / a > < / div >
---
## **Typer** , the FastAPI of CLIs
## **Typer** , FastAPI์ CLI
< a href = "https://typer.tiangolo.com" target = "_blank" > < img src = "https://typer.tiangolo.com/img/logo-margin/logo-margin-vector.svg" style = "width: 20%;" > < / a >
If you are building a < abbr title = "Command Line Interface" > CLI< / abbr > app to be used in the terminal instead of a web API, check out < a href = "https://typer.tiangolo.com/" class = "external-link" target = "_blank" > **Typer**< / a > .
์น API ๋์ ํฐ๋ฏธ๋์์ ์ฌ์ฉํ < abbr title = "Command Line Interface" > CLI< / abbr > ์ฑ์ ๋ง๋ค๊ณ ์๋ค๋ฉด, < a href = "https://typer.tiangolo.com/" class = "external-link" target = "_blank" > **Typer**< / a > ๋ฅผ ํ์ธํด ๋ณด์ธ์ .
**Typer** is FastAPI's little sibling. And it's intended to be the **FastAPI of CLIs** . โจ๏ธ ๐
**Typer**๋ FastAPI์ ๋์์
๋๋ค. ๊ทธ๋ฆฌ๊ณ **FastAPI์ CLI**๊ฐ ๋๊ธฐ ์ํด ์๊ฒผ์ต๋๋ค . โจ๏ธ ๐
## Requirements
## ์๊ตฌ์ฌํญ
Python 3.6+
FastAPI stands on the shoulders of giants :
FastAPI๋ ๊ฑฐ์ธ๋ค์ ์ด๊นจ ์์ ์ ์์ต๋๋ค :
* < a href = "https://www.starlette.io/" class = "external-link" target = "_blank" > Starlette< / a > for the web parts .
* < a href = "https://pydantic-docs.helpmanual.io/" class = "external-link" target = "_blank" > Pydantic< / a > for the data parts .
* ์น ๋ถ๋ถ์ ์ํ < a href = "https://www.starlette.io/" class = "external-link" target = "_blank" > Starlette< / a > .
* ๋ฐ์ดํฐ ๋ถ๋ถ์ ์ํ < a href = "https://pydantic-docs.helpmanual.io/" class = "external-link" target = "_blank" > Pydantic< / a > .
## Installation
## ์ค์น
< div class = "termy" >
@ -127,7 +123,7 @@ $ pip install fastapi
< / div >
You will also need an ASGI server, for production such as < a href = "http://www.uvicorn.org" class = "external-link" target = "_blank" > Uvicorn< / a > or < a href = "https://gitlab.com/pgjones/hypercorn" class = "external-link" target = "_blank" > Hypercorn< / a > .
ํ๋ก๋์
์ ์ํด < a href = "http://www.uvicorn.org" class = "external-link" target = "_blank" > Uvicorn< / a > ๋๋ < a href = "https://gitlab.com/pgjones/hypercorn" class = "external-link" target = "_blank" > Hypercorn< / a > ๊ณผ ๊ฐ์ ASGI ์๋ฒ๋ ํ์ํ ๊ฒ๋๋ค .
< div class = "termy" >
@ -139,11 +135,11 @@ $ pip install uvicorn
< / div >
## Example
## ์์
### Create it
### ๋ง๋ค๊ธฐ
* Create a file `main.py` with :
* `main.py` ํ์ผ์ ๋ง๋์ธ์ :
```Python
from typing import Optional
@ -164,9 +160,9 @@ def read_item(item_id: int, q: Optional[str] = None):
```
< details markdown = "1" >
< summary > Or use < code > async def< / code > ...< / summary >
< summary > ๋๋ < code > async def< / code > ์ฌ์ฉํ๊ธฐ ...< / summary >
If your code uses `async` / `await` , use `async def` :
์ฌ๋ฌ๋ถ์ ์ฝ๋๊ฐ `async` / `await` ์ ์ฌ์ฉํ๋ค๋ฉด , `async def` ๋ฅผ ์ฌ์ฉํ์ธ์ :
```Python hl_lines="9 14"
from typing import Optional
@ -188,13 +184,13 @@ async def read_item(item_id: int, q: Optional[str] = None):
**Note**:
If you don't know, check the _"In a hurry?"_ section about < a href = "https://fastapi.tiangolo.com/async/#in-a-hurry" target = "_blank" > `async` and `await` in the docs </ a > .
์ ๋ชจ๋ฅด๊ฒ ๋ค๋ฉด, < a href = "https://fastapi.tiangolo.com/async/#in-a-hurry" target = "_blank" > ๋ฌธ์์์ `async` ์ `await` </ a > ์ ๊ดํ _"๊ธํ์ธ์?"_ ์น์
์ ํ์ธํด ๋ณด์ธ์ .
< / details >
### Run it
### ์คํํ๊ธฐ
Run the server with :
์๋ฒ๋ฅผ ์คํํ์ธ์ :
< div class = "termy" >
@ -211,54 +207,54 @@ INFO: Application startup complete.
< / div >
< details markdown = "1" >
< summary > About the command < code > uvicorn main:app --reload< / code > ...< / summary >
< summary > < code > uvicorn main:app --reload< / code > ๋ช
๋ น์ ๊ดํ์ฌ ...< / summary >
The command `uvicorn main:app` refers to :
๋ช
๋ น `uvicorn main:app` ์ ๋ค์์ ๋ํ๋
๋๋ค :
* `main` : the file `main.py` (the Python "module ").
* `main` : `main.py` ํ์ผ (ํ์ด์ฌ "๋ชจ๋ ").
* `app` : the object created inside of `main.py` with the line `app = FastAPI()` .
* `--reload` : make the server restart after code changes. Only do this for development .
* `--reload` : ์ฝ๋๊ฐ ๋ณ๊ฒฝ๋ ํ ์๋ฒ ์ฌ์์ํ๊ธฐ. ๊ฐ๋ฐํ๊ฒฝ์์๋ง ์ฌ์ฉํ์ธ์ .
< / details >
### Check it
### ํ์ธํ๊ธฐ
Open your browser at < a href = "http://127.0.0.1:8000/items/5?q=somequery" class = "external-link" target = "_blank" > http://127.0.0.1:8000/items/5?q=somequery< / a > .
๋ธ๋ผ์ฐ์ ๋ก < a href = "http://127.0.0.1:8000/items/5?q=somequery" class = "external-link" target = "_blank" > http://127.0.0.1:8000/items/5?q=somequery< / a > ๋ฅผ ์ด์ด๋ณด์ธ์ .
You will see the JSON response as :
์๋์ JSON ์๋ต์ ๋ณผ ์ ์์ต๋๋ค :
```JSON
{"item_id": 5, "q": "somequery"}
```
You already created an API that :
์ฌ๋ฌ๋ถ์ ๋ฒ์จ API๋ฅผ ๋ง๋ค์์ต๋๋ค :
* Receives HTTP requests in the _paths_ `/` and `/items/{item_id}` .
* Both _paths_ take `GET` < em > operations</ em > (also known as HTTP _methods_ ) .
* The _path_ `/items/{item_id}` has a _path parameter_ `item_id` that should be an `int` .
* The _path_ `/items/{item_id}` has an optional `str` _query parameter_ `q` .
* _๊ฒฝ๋ก_ `/` ๋ฐ `/items/{item_id}` ์์ HTTP ์์ฒญ ๋ฐ๊ธฐ .
* ๋ _๊ฒฝ๋ก_ ๋ชจ๋ `GET` < em > ์ฐ์ฐ</ em > (HTTP _๋ฉ์๋_ ๋ก ์๋ ค์ง)์ ๋ฐ์ต๋๋ค .
* _๊ฒฝ๋ก_ `/items/{item_id}` ๋ _๊ฒฝ๋ก ๋งค๊ฐ๋ณ์_ `int` ํ ์ด์ด์ผ ํ๋ `item_id` ๋ฅผ ๊ฐ์ง๊ณ ์์ต๋๋ค .
* _๊ฒฝ๋ก_ `/items/{item_id}` ๋ ์ ํ์ ์ธ `str` ํ ์ด์ด์ผ ํ๋ _๊ฒฝ๋ก ๋งค๊ฐ๋ณ์_ `q` ๋ฅผ ๊ฐ์ง๊ณ ์์ต๋๋ค .
### Interactive API docs
### ๋ํํ API ๋ฌธ์
Now go to < a href = "http://127.0.0.1:8000/docs" class = "external-link" target = "_blank" > http://127.0.0.1:8000/docs< / a > .
์ด์ < a href = "http://127.0.0.1:8000/docs" class = "external-link" target = "_blank" > http://127.0.0.1:8000/docs< / a > ๋ก ๊ฐ๋ณด์ธ์ .
You will see the automatic interactive API documentation (provided by < a href = "https://github.com/swagger-api/swagger-ui" class = "external-link" target = "_blank" > Swagger UI< / a > ):
์๋ ๋ํํ API ๋ฌธ์๋ฅผ ๋ณผ ์ ์์ต๋๋ค ( < a href = "https://github.com/swagger-api/swagger-ui" class = "external-link" target = "_blank" > Swagger UI< / a > ์ ๊ณต ):

### Alternative API docs
### ๋์ API ๋ฌธ์
And now, go to < a href = "http://127.0.0.1:8000/redoc" class = "external-link" target = "_blank" > http://127.0.0.1:8000/redoc< / a > .
๊ทธ๋ฆฌ๊ณ ์ด์ < a href = "http://127.0.0.1:8000/redoc" class = "external-link" target = "_blank" > http://127.0.0.1:8000/redoc< / a > ๋ก ๊ฐ๋ณด์ธ์ .
You will see the alternative automatic documentation (provided by < a href = "https://github.com/Rebilly/ReDoc" class = "external-link" target = "_blank" > ReDoc< / a > ):
๋ค๋ฅธ ์๋ ๋ฌธ์๋ฅผ ๋ณผ ์ ์์ต๋๋ค( < a href = "https://github.com/Rebilly/ReDoc" class = "external-link" target = "_blank" > ReDoc< / a > ์ ๊ณต ):

## Example upgrade
## ์์ ๊ฐ์
Now modify the file `main.py` to receive a body from a `PUT` request .
์ด์ `PUT` ์์ฒญ์ ์๋ ๋ณธ๋ฌธ(Body)์ ๋ฐ๊ธฐ ์ํด `main.py` ๋ฅผ ์์ ํด๋ด
์๋ค .
Declare the body using standard Python types, thanks to Pydantic .
Pydantic์ ์ด์ฉํด ํ์ด์ฌ ํ์ค ํ์
์ผ๋ก ๋ณธ๋ฌธ์ ์ ์ธํฉ๋๋ค .
```Python hl_lines="4 9 10 11 12 25 26 27"
from typing import Optional
@ -290,175 +286,175 @@ def update_item(item_id: int, item: Item):
return {"item_name": item.name, "item_id": item_id}
```
The server should reload automatically (because you added `--reload` to the `uvicorn` command above ).
์๋ฒ๊ฐ ์๋์ผ๋ก ๋ฆฌ๋ก๋ฉ ํ ์ ์์ด์ผ ํฉ๋๋ค (์์์ `uvicorn` ๋ช
๋ น์ `--reload` ์ ์ถ๊ฐ ํ๊ธฐ ๋๋ฌธ์
๋๋ค ).
### Interactive API docs upgrade
### ๋ํํ API ๋ฌธ์ ์
๊ทธ๋ ์ด๋
Now go to < a href = "http://127.0.0.1:8000/docs" class = "external-link" target = "_blank" > http://127.0.0.1:8000/docs< / a > .
์ด์ < a href = "http://127.0.0.1:8000/docs" class = "external-link" target = "_blank" > http://127.0.0.1:8000/docs< / a > ๋ก ์ด๋ํฉ๋๋ค .
* The interactive API documentation will be automatically updated, including the new body :
* ๋ํํ API ๋ฌธ์๊ฐ ์ ๋ณธ๋ฌธ๊ณผ ํจ๊ป ์๋์ผ๋ก ์
๋ฐ์ดํธ ํฉ๋๋ค :

* Click on the button "Try it out", it allows you to fill the parameters and directly interact with the API :
* "Try it out" ๋ฒํผ์ ํด๋ฆญํ๋ฉด, ๋งค๊ฐ๋ณ์๋ฅผ ์ฑ์ธ ์ ์๊ฒ ํด์ฃผ๊ณ ์ง์ API์ ์ํธ์์ฉ ํ ์ ์์ต๋๋ค :

* Then click on the "Execute" button, the user interface will communicate with your API, send the parameters, get the results and show them on the screen :
* ๊ทธ๋ฌ๊ณ ๋์ "Execute" ๋ฒํผ์ ๋๋ฅด๋ฉด, ์ฌ์ฉ์ ์ธํฐํ์ด์ค๋ API์ ํต์ ํ๊ณ ๋งค๊ฐ๋ณ์๋ฅผ ์ ์กํ๋ฉฐ ๊ทธ ๊ฒฐ๊ณผ๋ฅผ ๊ฐ์ ธ์์ ํ๋ฉด์ ํ์ํฉ๋๋ค :

### Alternative API docs upgrade
### ๋์ API ๋ฌธ์ ์
๊ทธ๋ ์ด๋
And now, go to < a href = "http://127.0.0.1:8000/redoc" class = "external-link" target = "_blank" > http://127.0.0.1:8000/redoc< / a > .
๊ทธ๋ฆฌ๊ณ ์ด์ , < a href = "http://127.0.0.1:8000/redoc" class = "external-link" target = "_blank" > http://127.0.0.1:8000/redoc< / a > ๋ก ์ด๋ํฉ๋๋ค .
* The alternative documentation will also reflect the new query parameter and body :
* ๋์ ๋ฌธ์ ์ญ์ ์ ์ฟผ๋ฆฌ ๋งค๊ฐ๋ณ์์ ๋ณธ๋ฌธ์ ๋ฐ์ํฉ๋๋ค :

### Recap
### ์์ฝ
In summary, you declare **once** the types of parameters, body, etc. as function parameters.
์์ฝํ๋ฉด, ์ฌ๋ฌ๋ถ์ ๋งค๊ฐ๋ณ์์ ํ์
, ๋ณธ๋ฌธ ๋ฑ์ ํจ์ ๋งค๊ฐ๋ณ์๋ก์จ **ํ๋ฒ์** ์ ์ธํ์ต๋๋ค.
You do that with standard modern Python types .
์ฌ๋ฌ๋ถ์ ํ๋ ํ์ค ํ์ด์ฌ ํ์
์ผ๋ก ์ด๋ฅผ ํํ์ต๋๋ค .
You don't have to learn a new syntax, the methods or classes of a specific library, etc .
์๋ก์ด ๋ฌธ๋ฒ, ํน์ ๋ผ์ด๋ธ๋ฌ๋ฆฌ์ ๋ฉ์๋๋ ํด๋์ค ๋ฑ์ ๋ฐฐ์ธ ํ์๊ฐ ์์ต๋๋ค .
Just standard **Python 3.6+** .
๊ทธ์ ํ์ค **Python 3.6+**์
๋๋ค .
For example, for an `int` :
์๋ฅผ ๋ค์ด, `int` ์ ๋ํด์ :
```Python
item_id: int
```
or for a more complex `Item` model :
๋๋ ์ข ๋ ๋ณต์กํ `Item` ๋ชจ๋ธ์ ๋ํด์ :
```Python
item: Item
```
...and with that single declaration you get :
...๊ทธ๋ฆฌ๊ณ ๋จ ํ๋์ ์ ์ธ์ผ๋ก ์ฌ๋ฌ๋ถ์ด ์ป๋ ๊ฒ์ :
* Editor support, including :
* Completion .
* Type checks .
* Validation of data :
* Automatic and clear errors when the data is invalid .
* Validation even for deeply nested JSON objects .
* < abbr title = "also known as: serialization, parsing, marshalling" > Conversion < / abbr > of input data: coming from the network to Python data and types. Reading from :
* ๋ค์์ ํฌํจํ ํธ์ง๊ธฐ ์ง์ :
* ์๋์์ฑ .
* ํ์
๊ฒ์ฌ .
* ๋ฐ์ดํฐ ๊ฒ์ฆ :
* ๋ฐ์ดํฐ๊ฐ ์ ํจํ์ง ์์ ๋ ์๋์ผ๋ก ์์ฑํ๋ ๋ช
ํํ ์๋ฌ .
* ์ค์ฒฉ๋ JSON ๊ฐ์ฒด์ ๋ํ ์ ํจ์ฑ ๊ฒ์ฌ .
* ์
๋ ฅ ๋ฐ์ดํฐ < abbr title = "๋ค์์ผ๋ก ์๋ ค์ง: ์ง๋ ฌํ, ํ์ฑ, ๋ง์ฌ๋ง" > ๋ณํ < / abbr > : ๋คํธ์ํฌ์์ ํ์ด์ฌ ๋ฐ์ดํฐ ๋ฐ ํ์
์ผ๋ก ์ ์ก. ์ฝ์ ์ ์๋ ๊ฒ๋ค :
* JSON.
* Path parameters .
* Query parameters .
* Cookies .
* Headers .
* Forms.
* Files .
* < abbr title = "also known as: serialization, parsing, marshalling" > Conversion < / abbr > of output data: converting from Python data and types to network data (as JSON ):
* Convert Python types (`str`, `int` , `float` , `bool` , `list` , etc ).
* `datetime` objects .
* `UUID` objects .
* Database models .
* ...and many more .
* Automatic interactive API documentation, including 2 alternative user interfaces :
* ๊ฒฝ๋ก ๋งค๊ฐ๋ณ์ .
* ์ฟผ๋ฆฌ ๋งค๊ฐ๋ณ์ .
* ์ฟ ํค .
* ํค๋ .
* ํผ( Forms) .
* ํ์ผ .
* ์ถ๋ ฅ ๋ฐ์ดํฐ < abbr title = "๋ค์์ผ๋ก ์๋ ค์ง: ์ง๋ ฌํ, ํ์ฑ, ๋ง์ฌ๋ง" > ๋ณํ < / abbr > : ํ์ด์ฌ ๋ฐ์ดํฐ ๋ฐ ํ์
์ ๋คํธ์ํฌ ๋ฐ์ดํฐ๋ก ์ ํ(JSON ํ์์ผ๋ก ):
* ํ์ด์ฌ ํ์
๋ณํ (`str`, `int` , `float` , `bool` , `list` , ๋ฑ ).
* `datetime` ๊ฐ์ฒด .
* `UUID` ๊ฐ์ฒด .
* ๋ฐ์ดํฐ๋ฒ ์ด์ค ๋ชจ๋ธ .
* ...๋ ๋ง์ ๊ฒ๋ค .
* ๋์๊ฐ๋ฅํ ์ฌ์ฉ์ ์ธํฐํ์ด์ค๋ฅผ 2๊ฐ ํฌํจํ ์๋ ๋ํํ API ๋ฌธ์ :
* Swagger UI.
* ReDoc.
---
Coming back to the previous code example, **FastAPI** will :
* Validate that there is an `item_id` in the path for `GET` and `PUT` requests .
* Validate that the `item_id` is of type `int` for `GET` and `PUT` requests .
* If it is not, the client will see a useful, clear error .
* Check if there is an optional query parameter named `q` (as in `http://127.0.0.1:8000/items/foo?q=somequery` ) for `GET` requests .
* As the `q` parameter is declared with `= None` , it is optional .
* Without the `None` it would be required (as is the body in the case with `PUT` ).
* For `PUT` requests to `/items/{item_id}` , Read the body as JSON :
* Check that it has a required attribute `name` that should be a `str` .
* Check that it has a required attribute `price` that has to be a `float` .
* Check that it has an optional attribute `is_offer` , that should be a `bool` , if present .
* All this would also work for deeply nested JSON objects .
* Convert from and to JSON automatically .
* Document everything with OpenAPI, that can be used by :
* Interactive documentation systems .
* Automatic client code generation systems, for many languages .
* Provide 2 interactive documentation web interfaces directly .
์ด์ ์ฝ๋ ์์ ๋ก ๋์๊ฐ์, **FastAPI**๋ ๋ค์์ฒ๋ผ ์ฒ๋ฆฌํฉ๋๋ค :
* `GET` ๋ฐ `PUT` ์์ฒญ์ `item_id` ๊ฐ ๊ฒฝ๋ก์ ์๋์ง ๊ฒ์ฆ .
* `GET` ๋ฐ `PUT` ์์ฒญ์ `item_id` ๊ฐ `int` ํ์
์ธ์ง ๊ฒ์ฆ .
* ๊ทธ๋ ์ง ์๋ค๋ฉด ํด๋ผ์ด์ธํธ๋ ์ ์ฉํ๊ณ ๋ช
ํํ ์๋ฌ๋ฅผ ๋ณผ ์ ์์ต๋๋ค .
* `GET` ์์ฒญ์ `q` ๋ผ๋ ์ ํ์ ์ธ ์ฟผ๋ฆฌ ๋งค๊ฐ๋ณ์๊ฐ ๊ฒ์ฌ(`http://127.0.0.1:8000/items/foo?q=somequery`์ฒ๋ผ) .
* `q` ๋งค๊ฐ๋ณ์๋ `= None` ์ผ๋ก ์ ์ธ๋์๊ธฐ ๋๋ฌธ์ ์ ํ์ฌํญ์
๋๋ค .
* `None` ์ด ์๋ค๋ฉด ํ์์ฌํญ์
๋๋ค(`PUT`์ ๊ฒฝ์ฐ์ ๋ง์ฐฌ๊ฐ์ง๋ก ).
* `/items/{item_id}` ์ผ๋ก์ `PUT` ์์ฒญ์ ๋ณธ๋ฌธ์ JSON์ผ๋ก ์ฝ์ :
* `name` ์ ํ์ ์์ฑ์ผ๋ก ๊ฐ๊ณ `str` ํ์ธ์ง ๊ฒ์ฌ.
* `price` ์ ํ์ ์์ฑ์ผ๋ก ๊ฐ๊ณ `float` ํ์ธ์ง ๊ฒ์ฌ .
* ๋ง์ฝ ์ฃผ์ด์ง๋ค๋ฉด, `is_offer` ๋ฅผ ์ ํ ์์ฑ์ผ๋ก ๊ฐ๊ณ `bool` ํ์ธ์ง ๊ฒ์ฌ .
* ์ด ๋ชจ๋ ๊ฒ์ ๊น์ด ์ค์ฒฉ๋ JSON ๊ฐ์ฒด์๋ ์ ์ฉ๋ฉ๋๋ค .
* JSON์ผ๋ก, ๊ทธ๋ฆฌ๊ณ ์์๋ถํฐ ์๋ ๋ณํ .
* ๋ค์์์ ์ฌ์ฉํ ์ ์๋ ๋ชจ๋ ๊ฒ์ OpenAPI๋ก ๋ฌธ์ํ :
* ๋ํํ ๋ฌธ์ ์์คํ
.
* ์ฌ๋ฌ ์ธ์ด๋ค์ ๋ํ ์๋ ํด๋ผ์ด์ธํธ ์ฝ๋ ์์ฑ ์์คํ
.
* 2๊ฐ์ ๋ํํ ๋ฌธ์ ์น ์ธํฐํ์ด์ค๋ฅผ ์ง์ ์ ๊ณต .
---
We just scratched the surface, but you already get the idea of how it all works .
์ฐ๋ฆฌ๋ ๊ทธ์ ์๋ฐ ๊ฒํก๊ธฐ๋ง ํ์ ๋ฟ์ธ๋ฐ ์ฌ๋ฌ๋ถ์ ๋ฒ์จ ์ด๋ป๊ฒ ์๋ํ๋์ง ์๊ณ ์์ต๋๋ค .
Try changing the line with :
๋ค์ ์ค์ ๋ฐ๊ฟ๋ณด์ธ์ :
```Python
return {"item_name": item.name, "item_id": item_id}
```
...from :
...์์ :
```Python
... "item_name": item.name ...
```
...to :
...์ผ๋ก :
```Python
... "item_price": item.price ...
```
...and see how your editor will auto-complete the attributes and know their types :
...๊ทธ๋ฌ๊ณ ๋์ ์ฌ๋ฌ๋ถ์ ํธ์ง๊ธฐ๊ฐ ์์ฑ๊ณผ ํ์
์ ์๊ณ ์๋ ์์ฑํ๋์ง ๋ณด์ธ์ :

For a more complete example including more features, see the < a href = "https://fastapi.tiangolo.com/tutorial/" > Tutorial - User Guide < / a > .
๋ ๋ง์ ๊ธฐ๋ฅ์ ํฌํจํ ๋ณด๋ค ์์ ํ ์์ ์ ๊ฒฝ์ฐ, < a href = "https://fastapi.tiangolo.com/tutorial/" > ํํ ๋ฆฌ์ผ - ์ฌ์ฉ์ ๊ฐ์ด๋ < / a > ๋ฅผ ๋ณด์ธ์ .
**Spoiler alert**: the tutorial - user guide includes :
**์คํฌ์ผ๋ฌ ์ฃผ์**: ํํ ๋ฆฌ์ผ - ์ฌ์ฉ์ ๊ฐ์ด๋๋ :
* Declaration of **parameters** from other different places as: **headers** , **cookies** , **form fields** and **files ** .
* How to set **validation constraints** as `maximum_length` or `regex` .
* A very powerful and easy to use ** < abbr title = "also known as components, resources, providers, services, injectables" > Dependency Injection</ abbr > ** system .
* Security and authentication, including support for **OAuth2** with **JWT tokens** and **HTTP Basic** auth .
* More advanced (but equally easy) techniques for declaring **deeply nested JSON models** (thanks to Pydantic) .
* Many extra features (thanks to Starlette) as :
* * *WebSockets **
* ์๋ก ๋ค๋ฅธ ์ฅ์์์ **๋งค๊ฐ๋ณ์** ์ ์ธ: **ํค๋** , **์ฟ ํค** , **ํผ ํ๋** ๊ทธ๋ฆฌ๊ณ **ํ์ผ ** .
* `maximum_length` ๋๋ `regex` ์ฒ๋ผ **์ ํจ์ฑ ์ ์ฝ**ํ๋ ๋ฐฉ๋ฒ .
* ๊ฐ๋ ฅํ๊ณ ์ฌ์ฉํ๊ธฐ ์ฌ์ด ** < abbr title = "์ปดํฌ๋ํธ, ๋ฆฌ์์ค, ์ ๊ณต์, ์๋น์ค, injectables๋ผ ์๋ ค์ง" > ์์กด์ฑ ์ฃผ์
</ abbr > ** ์์คํ
.
* **OAuth2** ์ง์์ ํฌํจํ **JWT tokens** ๋ฐ **HTTP Basic**์ ๊ฐ๋ ๋ณด์๊ณผ ์ธ์ฆ .
* (Pydantic ๋๋ถ์) **๊น์ ์ค์ฒฉ JSON ๋ชจ๋ธ**์ ์ ์ธํ๋๋ฐ ๋ ์ง๋ณดํ (ํ์ง๋ง ๋ง์ฐฌ๊ฐ์ง๋ก ์ฌ์ด) ๊ธฐ์ .
* (Starlette ๋๋ถ์) ๋ง์ ์ถ๊ฐ ๊ธฐ๋ฅ :
* * *์น ์์ผ **
* * *GraphQL**
* extremely easy tests based on `requests` and `pytest`
* `requests` ๋ฐ `pytest` ์ ๊ธฐ๋ฐํ ๊ทนํ ์ฌ์ด ํ
์คํธ
* * *CORS**
* * *Cookie Sessions **
* ...and more .
* * *์ฟ ํค ์ธ์
**
* ...๊ธฐํ ๋ฑ๋ฑ .
## Performance
## ์ฑ๋ฅ
Independent TechEmpower benchmarks show **FastAPI** applications running under Uvicorn as < a href = "https://www.techempower.com/benchmarks/#section=test&runid=7464e520-0dc2-473d-bd34-dbdfd7e85911&hw=ph&test=query&l=zijzen-7" class = "external-link" target = "_blank" > one of the fastest Python frameworks available</ a > , only below Starlette and Uvicorn themselves (used internally by FastAPI) . (*)
๋
๋ฆฝ๋ TechEmpower ๋ฒค์น๋งํฌ์์ Uvicorn์์ ์๋ํ๋ FastAPI ์ดํ๋ฆฌ์ผ์ด์
์ด < a href = "https://www.techempower.com/benchmarks/#section=test&runid=7464e520-0dc2-473d-bd34-dbdfd7e85911&hw=ph&test=query&l=zijzen-7" class = "external-link" target = "_blank" > ์ฌ์ฉ ๊ฐ๋ฅํ ๊ฐ์ฅ ๋น ๋ฅธ ํ๋ ์์ํฌ ์ค ํ๋< / a > ๋ก Starlette์ Uvicorn(FastAPI์์ ๋ด๋ถ์ ์ผ๋ก ์ฌ์ฉ)์๋ง ๋ฐ๋๊ณ ์์ต๋๋ค . (*)
To understand more about it, see the section < a href = "https://fastapi.tiangolo.com/benchmarks/" class = "internal-link" target = "_blank" > Benchmarks < / a > .
์์ธํ ๋ด์ฉ์ < a href = "https://fastapi.tiangolo.com/benchmarks/" class = "internal-link" target = "_blank" > ๋ฒค์น๋งํฌ < / a > ์น์
์ ๋ณด์ธ์ .
## Optional Dependencies
## ์ ํ๊ฐ๋ฅํ ์ข
์์ฌํญ
Used by Pydantic:
Pydantic์ด ์ฌ์ฉํ๋ :
* < a href = "https://github.com/esnme/ultrajson" target = "_blank" > < code > ujson< / code > < / a > - for faster JSON < abbr title = "converting the string that comes from an HTTP request into Python data" > "parsing "< / abbr > .
* < a href = "https://github.com/JoshData/python-email-validator" target = "_blank" > < code > email_validator< / code > < / a > - for email validation .
* < a href = "https://github.com/esnme/ultrajson" target = "_blank" > < code > ujson< / code > < / a > - ๋ ๋น ๋ฅธ JSON < abbr title = "HTTP ์์ฒญ์์ ํ์ด์ฌ ๋ฐ์ดํฐ๋ก ๊ฐ๋ ๋ฌธ์์ด ๋ณํ" > "ํ์ฑ "< / abbr > .
* < a href = "https://github.com/JoshData/python-email-validator" target = "_blank" > < code > email_validator< / code > < / a > - ์ด๋ฉ์ผ ์ ํจ์ฑ ๊ฒ์ฌ .
Used by Starlette:
Starlette์ด ์ฌ์ฉํ๋ :
* < a href = "http://docs.python-requests.org" target = "_blank" >< code > requests</ code ></ a > - Required if you want to use the `TestClient` .
* < a href = "https://github.com/Tinche/aiofiles" target = "_blank" >< code > aiofiles</ code ></ a > - Required if you want to use `FileResponse` or `StaticFiles` .
* < a href = "http://jinja.pocoo.org" target = "_blank" > < code > jinja2< / code > < / a > - Required if you want to use the default template configuration .
* < a href = "https://andrew-d.github.io/python-multipart/" target = "_blank" >< code > python-multipart</ code ></ a > - Required if you want to support form < abbr title = "converting the string that comes from an HTTP request into Python data " > "parsing"</ abbr > , with `request.form()` .
* < a href = "https://pythonhosted.org/itsdangerous/" target = "_blank" >< code > itsdangerous</ code ></ a > - Required for `SessionMiddleware` support .
* < a href = "https://pyyaml.org/wiki/PyYAMLDocumentation" target = "_blank" >< code > pyyaml</ code ></ a > - Required for Starlette's `SchemaGenerator` support (you probably don't need it with FastAPI ).
* < a href = "https://graphene-python.org/" target = "_blank" >< code > graphene</ code ></ a > - Required for `GraphQLApp` support .
* < a href = "https://github.com/esnme/ultrajson" target = "_blank" >< code > ujson</ code ></ a > - Required if you want to use `UJSONResponse` .
* < a href = "http://docs.python-requests.org" target = "_blank" >< code > requests</ code ></ a > - `TestClient` ๋ฅผ ์ฌ์ฉํ๋ ค๋ฉด ํ์ .
* < a href = "https://github.com/Tinche/aiofiles" target = "_blank" >< code > aiofiles</ code ></ a > - `FileResponse` ๋๋ `StaticFiles` ๋ฅผ ์ฌ์ฉํ๋ ค๋ฉด ํ์ .
* < a href = "http://jinja.pocoo.org" target = "_blank" > < code > jinja2< / code > < / a > - ๊ธฐ๋ณธ ํ
ํ๋ฆฟ ์ค์ ์ ์ฌ์ฉํ๋ ค๋ฉด ํ์ .
* < a href = "https://andrew-d.github.io/python-multipart/" target = "_blank" >< code > python-multipart</ code ></ a > - `request.form()` ๊ณผ ํจ๊ป < abbr title = "HTTP ์์ฒญ์์ ํ์ด์ฌ ๋ฐ์ดํฐ๋ก ๊ฐ๋ ๋ฌธ์์ด ๋ณํ " > "parsing"</ abbr > ์ ์ง์์ ์ํ๋ฉด ํ์ .
* < a href = "https://pythonhosted.org/itsdangerous/" target = "_blank" >< code > itsdangerous</ code ></ a > - `SessionMiddleware` ์ง์์ ์ํด ํ์ .
* < a href = "https://pyyaml.org/wiki/PyYAMLDocumentation" target = "_blank" >< code > pyyaml</ code ></ a > - Starlette์ `SchemaGenerator` ์ง์์ ์ํด ํ์ (FastAPI์ ์ธ๋๋ ํ์๊ฐ ์์ ๊ฒ๋๋ค ).
* < a href = "https://graphene-python.org/" target = "_blank" >< code > graphene</ code ></ a > - `GraphQLApp` ์ง์์ ์ํด ํ์ .
* < a href = "https://github.com/esnme/ultrajson" target = "_blank" >< code > ujson</ code ></ a > - `UJSONResponse` ๋ฅผ ์ฌ์ฉํ๋ ค๋ฉด ํ์ .
Used by FastAPI / Starlette:
FastAPI / Starlette์ด ์ฌ์ฉํ๋ :
* < a href = "http://www.uvicorn.org" target = "_blank" > < code > uvicorn< / code > < / a > - for the server that loads and serves your application .
* < a href = "https://github.com/ijl/orjson" target = "_blank" >< code > orjson</ code ></ a > - Required if you want to use `ORJSONResponse` .
* < a href = "http://www.uvicorn.org" target = "_blank" > < code > uvicorn< / code > < / a > - ์ ํ๋ฆฌ์ผ์ด์
์ ๋ก๋ํ๊ณ ์ ๊ณตํ๋ ์๋ฒ .
* < a href = "https://github.com/ijl/orjson" target = "_blank" >< code > orjson</ code ></ a > - `ORJSONResponse` ์ ์ฌ์ฉํ๋ ค๋ฉด ํ์ .
You can install all of these with `pip install fastapi[all]` .
`pip install fastapi[all]` ๋ฅผ ํตํด ์ด ๋ชจ๋๋ฅผ ์ค์น ํ ์ ์์ต๋๋ค .
## License
## ๋ผ์ด์ผ์ค
This project is licensed under the terms of the MIT license .
์ด ํ๋ก์ ํธ๋ MIT ๋ผ์ด์ผ์ค ์กฐ์ฝ์ ๋ฐ๋ผ ๋ผ์ด์ผ์ค๊ฐ ๋ถ์ฌ๋ฉ๋๋ค .