FastAPI에서 OpenAPI 사양을 사용하여 API 인터페이스를 정의하는 방법
소개:
웹 API를 작성할 때 좋은 API 문서가 매우 중요합니다. 개발자가 API를 빠르게 이해하고 사용할 수 있도록 명확한 문서와 인터페이스 정의를 제공할 수 있습니다. OpenAPI 사양은 표준 기반 방식으로 API 문서를 정의하고 생성할 수 있는 강력한 기능과 생태계 지원을 갖춘 범용 API 설명 언어입니다. FastAPI는 OpenAPI 사양을 완벽하게 통합하고 강력한 자동화된 문서 생성 및 확인 기능을 제공하는 최신 Python 웹 프레임워크입니다. 이 기사에서는 OpenAPI 사양을 사용하여 FastAPI에서 API 인터페이스를 정의하고 해당 코드 예제를 제공하는 방법을 소개합니다.
1. FastAPI 및 pydantic 라이브러리 설치
시작하기 전에 FastAPI 및 pydantic 라이브러리를 설치해야 합니다. 다음 명령을 통해 설치할 수 있습니다.
pip install fastapi pip install uvicorn[standard] pip install pydantic
2. 간단한 API 인터페이스 만들기
먼저 OpenAPI 사양을 사용하는 방법을 보여주기 위해 간단한 API 인터페이스를 만듭니다. main.py
라는 파일에 다음 코드를 작성합니다. main.py
的文件中,写入以下代码:
from fastapi import FastAPI app = FastAPI() @app.get("/hello") def hello(): return {"message": "Hello, World!"}
这段代码创建了一个/hello
的GET请求接口,并返回一个包含message
字段的JSON响应。接下来,我们需要运行这个应用。可以通过以下命令来运行:
uvicorn main:app --reload
三、生成OpenAPI文档
运行应用后,可以在浏览器中打开http://localhost:8000/docs
来访问自动生成的API文档。这个页面是由FastAPI自动生成基于OpenAPI规范的文档。你可以看到/hello
接口的详细信息,包括路径、请求方法、请求参数和响应示例。并且,你还可以在文档页面中测试这个接口。
四、使用参数定义
在现实的应用中,我们通常需要使用参数来接收用户的输入。FastAPI提供了多种方式来定义参数,包括路径参数、查询参数、请求体参数和请求头参数。下面我们将演示如何使用这些参数。
4.1 路径参数
路径参数是URL中的一部分,它们用于接收动态变量。我们可以通过{}
来定义一个路径参数。在下面的示例中,我们创建了一个接受用户ID作为路径参数的接口。
from fastapi import FastAPI app = FastAPI() @app.get("/users/{user_id}") def get_user(user_id: int): return {"user_id": user_id}
通过运行应用,然后在浏览器中访问http://localhost:8000/users/1
,你将得到一个JSON响应{"user_id": 1}
。
4.2 查询参数
查询参数是URL中的一部分,用于接收用户传递的键值对。在FastAPI中,查询参数可以通过函数参数中的默认值来定义。在下面的示例中,我们创建了一个接受limit
和offset
查询参数的接口。
from fastapi import FastAPI app = FastAPI() @app.get("/users/") def get_users(limit: int = 10, offset: int = 0): return {"limit": limit, "offset": offset}
通过运行应用,然后在浏览器中访问http://localhost:8000/users/?limit=20&offset=10
,你将得到一个JSON响应{"limit": 20, "offset": 10}
。
4.3 请求体参数
请求体参数是通过HTTP请求体传递的数据,通常用于接收较大的数据。在FastAPI中,请求体参数可以通过pydantic
库的模型来定义。在下面的示例中,我们创建了一个接受用户信息作为请求体参数的接口。
from fastapi import FastAPI from pydantic import BaseModel app = FastAPI() class User(BaseModel): name: str age: int @app.post("/users/") def create_user(user: User): return {"user": user}
运行应用后,使用工具如curl
发送一个POST请求:
curl -X POST -H "Content-Type: application/json" -d '{"name":"Alice", "age": 25}' http://localhost:8000/users/
你将得到一个JSON响应{"user": {"name": "Alice", "age": 25}}
。
4.4 请求头参数
请求头参数是通过HTTP请求头传递的参数,通常用于传递安全验证信息。在FastAPI中,请求头参数可以在函数参数中使用Header()
方法来定义。在下面的示例中,我们创建了一个接受api_key
请求头参数的接口。
from fastapi import FastAPI, Header app = FastAPI() @app.get("/protected/") def protected(api_key: str = Header(...)): return {"api_key": api_key}
通过运行应用,然后在浏览器中访问http://localhost:8000/protected/
并携带自定义的api_key
请求头,你将得到一个JSON响应{"api_key": <your_api_key>}</your_api_key>
rrreee
/hello
에 대한 GET 요청 인터페이스를 생성하고 다음에 대한 JSON 응답이 포함된 GET 요청 인터페이스를 반환합니다. 메시지
필드. 다음으로 애플리케이션을 실행해야 합니다. 다음 명령을 통해 실행할 수 있습니다: rrreee
3. OpenAPI 문서 생성
http://localhost:8000/docs
를 열어 자동으로 생성된 문서에 액세스할 수 있습니다. API 문서. 이 페이지는 OpenAPI 사양을 기반으로 FastAPI에서 자동 생성된 문서입니다. 경로, 요청 메서드, 요청 매개변수, 응답 예시를 포함하여 /hello
인터페이스의 세부정보를 볼 수 있습니다. 또한 설명서 페이지에서 이 인터페이스를 테스트할 수도 있습니다. 🎜🎜4. 매개변수 정의 사용🎜실제 애플리케이션에서는 일반적으로 사용자 입력을 받기 위해 매개변수를 사용해야 합니다. FastAPI는 경로 매개변수, 쿼리 매개변수, 요청 본문 매개변수, 요청 헤더 매개변수 등 매개변수를 정의하는 다양한 방법을 제공합니다. 아래에서는 이러한 매개변수를 사용하는 방법을 보여줍니다. 🎜🎜4.1 경로 매개변수🎜경로 매개변수는 URL의 일부이며 동적 변수를 받는 데 사용됩니다. {}
를 통해 경로 매개변수를 정의할 수 있습니다. 아래 예에서는 사용자 ID를 경로 매개변수로 받아들이는 인터페이스를 만듭니다. 🎜rrreee🎜앱을 실행한 다음 브라우저에서 http://localhost:8000/users/1
를 방문하면 JSON 응답 {"user_id": 1}을 받게 됩니다. 코드>. 🎜🎜4.2 쿼리 매개변수🎜 쿼리 매개변수는 URL의 일부이며 사용자가 전달한 키-값 쌍을 받는 데 사용됩니다. FastAPI에서는 함수 매개변수의 기본값을 통해 쿼리 매개변수를 정의할 수 있습니다. 아래 예에서는 limit
및 offset
쿼리 매개변수를 허용하는 인터페이스를 만듭니다. 🎜rrreee🎜앱을 실행한 다음 브라우저에서 http://localhost:8000/users/?limit=20&offset=10
에 액세스하면 JSON 응답 {"limit"을 받게 됩니다. : 20, "오프셋": 10}
. 🎜🎜4.3 요청 본문 매개변수🎜요청 본문 매개변수는 HTTP 요청 본문을 통해 전달되는 데이터이며 일반적으로 더 큰 데이터를 수신하는 데 사용됩니다. FastAPI에서 요청 본문 매개변수는 pydantic
라이브러리 모델을 통해 정의할 수 있습니다. 다음 예에서는 사용자 정보를 요청 본문 매개변수로 받아들이는 인터페이스를 만듭니다. 🎜rrreee🎜애플리케이션을 실행한 후 curl
과 같은 도구를 사용하여 POST 요청을 보냅니다. 🎜rrreee🎜JSON 응답을 받게 됩니다. {"user": {"name": " 앨리스", "나이": 25}}
. 🎜🎜4.4 요청 헤더 매개변수🎜요청 헤더 매개변수는 HTTP 요청 헤더를 통해 전달되는 매개변수이며 일반적으로 보안 확인 정보를 전달하는 데 사용됩니다. FastAPI에서는 함수 매개변수의 Header()
메서드를 사용하여 요청 헤더 매개변수를 정의할 수 있습니다. 아래 예에서는 api_key
요청 헤더 매개변수를 허용하는 인터페이스를 만듭니다. 🎜rrreee🎜애플리케이션을 실행한 다음 브라우저에서 http://localhost:8000/protected/
에 액세스하고 사용자 정의 api_key
요청 헤더를 전달하면 JSON을 얻을 수 있습니다. 응답 {"api_key": <your_api_key>}</your_api_key>
. 🎜🎜결론: 🎜이 글에서는 OpenAPI 사양을 사용하여 FastAPI에서 API 인터페이스를 정의하는 방법을 소개합니다. FastAPI에서 제공하는 데코레이터와 매개변수 유형 주석을 사용하여 API 인터페이스를 쉽게 정의하고 확인할 수 있습니다. 자동으로 생성된 OpenAPI 문서를 통해 API 인터페이스를 빠르게 이해하고 사용할 수 있으며, 다른 개발자와 쉽게 협업하고 소통할 수 있습니다. 이 기사가 FastAPI에서 API 인터페이스를 더 잘 정의하고 사용하는 데 도움이 되기를 바랍니다. 🎜
위 내용은 FastAPI에서 OpenAPI 사양을 사용하여 API 인터페이스를 정의하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

파이썬은 자동화, 스크립팅 및 작업 관리가 탁월합니다. 1) 자동화 : 파일 백업은 OS 및 Shutil과 같은 표준 라이브러리를 통해 실현됩니다. 2) 스크립트 쓰기 : PSUTIL 라이브러리를 사용하여 시스템 리소스를 모니터링합니다. 3) 작업 관리 : 일정 라이브러리를 사용하여 작업을 예약하십시오. Python의 사용 편의성과 풍부한 라이브러리 지원으로 인해 이러한 영역에서 선호하는 도구가됩니다.

제한된 시간에 Python 학습 효율을 극대화하려면 Python의 DateTime, Time 및 Schedule 모듈을 사용할 수 있습니다. 1. DateTime 모듈은 학습 시간을 기록하고 계획하는 데 사용됩니다. 2. 시간 모듈은 학습과 휴식 시간을 설정하는 데 도움이됩니다. 3. 일정 모듈은 주간 학습 작업을 자동으로 배열합니다.

Python은 게임 및 GUI 개발에서 탁월합니다. 1) 게임 개발은 Pygame을 사용하여 드로잉, 오디오 및 기타 기능을 제공하며 2D 게임을 만드는 데 적합합니다. 2) GUI 개발은 Tkinter 또는 PYQT를 선택할 수 있습니다. Tkinter는 간단하고 사용하기 쉽고 PYQT는 풍부한 기능을 가지고 있으며 전문 개발에 적합합니다.

Python은 데이터 과학, 웹 개발 및 자동화 작업에 적합한 반면 C는 시스템 프로그래밍, 게임 개발 및 임베디드 시스템에 적합합니다. Python은 단순성과 강력한 생태계로 유명하며 C는 고성능 및 기본 제어 기능으로 유명합니다.

2 시간 이내에 Python의 기본 프로그래밍 개념과 기술을 배울 수 있습니다. 1. 변수 및 데이터 유형을 배우기, 2. 마스터 제어 흐름 (조건부 명세서 및 루프), 3. 기능의 정의 및 사용을 이해하십시오. 4. 간단한 예제 및 코드 스 니펫을 통해 Python 프로그래밍을 신속하게 시작하십시오.

Python은 웹 개발, 데이터 과학, 기계 학습, 자동화 및 스크립팅 분야에서 널리 사용됩니다. 1) 웹 개발에서 Django 및 Flask 프레임 워크는 개발 프로세스를 단순화합니다. 2) 데이터 과학 및 기계 학습 분야에서 Numpy, Pandas, Scikit-Learn 및 Tensorflow 라이브러리는 강력한 지원을 제공합니다. 3) 자동화 및 스크립팅 측면에서 Python은 자동화 된 테스트 및 시스템 관리와 같은 작업에 적합합니다.

2 시간 이내에 파이썬의 기본 사항을 배울 수 있습니다. 1. 변수 및 데이터 유형을 배우십시오. 이를 통해 간단한 파이썬 프로그램 작성을 시작하는 데 도움이됩니다.

10 시간 이내에 컴퓨터 초보자 프로그래밍 기본 사항을 가르치는 방법은 무엇입니까? 컴퓨터 초보자에게 프로그래밍 지식을 가르치는 데 10 시간 밖에 걸리지 않는다면 무엇을 가르치기로 선택 하시겠습니까?


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

맨티스BT
Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

Eclipse용 SAP NetWeaver 서버 어댑터
Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

VSCode Windows 64비트 다운로드
Microsoft에서 출시한 강력한 무료 IDE 편집기

SublimeText3 영어 버전
권장 사항: Win 버전, 코드 프롬프트 지원!

ZendStudio 13.5.1 맥
강력한 PHP 통합 개발 환경
