작성자 없음
작성자 정보가 삭제된 글입니다.
해결된 질문
작성
·
66
답변 3
0
from fastapi import FastAPI
from pydantic import BaseModel
app=FastAPI()
@app.get("/")
def health_check_handler():
return {"ping": "pong"}
todo_data = {
1:{
"id":1,
"content": "실전! FastAPI 섹션 0 수강",
"is_done": True,
},
2: {
"id": 2,
"content": "실전! FastAPI 섹션 1 수강",
"is_done": False,
},
3: {
"id": 3,
"content": "실전! FastAPI 섹션 2 수강",
"is_done": True,
},
}
@app.get("/todos")
def get_todos_handler(order: str | None=None):
ret = list(todo_data.values())
if order and order == "DESC":
return ret[::-1]
return ret
@app.get("/todos/{todo_id}") ## 단일조회
def get_todo_handler(todo_id: int):
return todo_data.get(todo_id,{})
class CreateToDoRequest(BaseModel):
id: int
content: str
is_done: bool
@app.post("/todos")
def create_todo_handler(request: CreateToDoRequest):
todo_data[request.id] = request.dict()
return todo_data[request.id]
0
0
안녕하세요, 인프런 AI 인턴입니다.
이수빈님께서 겪고 계신 문제는 FastAPI의 POST
요청에 대한 매개변수 설정과 관련된 내용으로 보입니다. 강의 내용과 동일하게 따라 했다면, FastAPI에서 요청 본문을 처리하는 부분에서 설정이 누락되었을 가능성이 큽니다. 일반적으로 POST
요청에서 JSON 데이터를 받기 위해서는 Pydantic
모델을 활용하여 요청 본문을 정의해야 합니다.
POST
메서드 내에서 받을 request body를 정의하는 Pydantic
모델이 정의되어야 합니다. 예를 들어: from pydantic import BaseModel
class CreateTodoRequest(BaseModel):
id: int
content: str
is_done: bool
POST
요청이 올바르게 Pydantic 모델을 수용하도록 경로를 설정해야 합니다. @app.post("/todos")
def create_todo_handler(request: CreateTodoRequest):
# 처리 로직
return {"message": "Todo created"}
이러한 설정을 통해 Swagger에서 JSON 데이터를 요청 본문으로 보내는 것이 가능해집니다.
관련해서 유익한 자료로 어떤 테스트 코드에서 발생할 수 있는 일반적인 문제 및 솔루션을 참조하실 수 있습니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
안녕하세요, 작성하신 코드를 함께 첨부해주시겠어요?