콘텐츠로 이동

응답 - 상태 코드 변경

기본 응답 상태 코드 설정이 가능하다는 걸 이미 알고 계실 겁니다.

하지만 경우에 따라 기본 설정과 다른 상태 코드를 반환해야 할 때가 있습니다.

사용 예

예를 들어 기본적으로 HTTP 상태 코드 "OK" 200을 반환하고 싶다고 가정해 봅시다.

하지만 데이터가 존재하지 않으면 이를 새로 생성하고, HTTP 상태 코드 "CREATED" 201을 반환하고자 할 때가 있을 수 있습니다.

이때도 여전히 response_model을 사용하여 반환하는 데이터를 필터링하고 변환하고 싶을 수 있습니다.

이런 경우에는 Response 파라미터를 사용할 수 있습니다.

Response 파라미터 사용하기

경로 작동 함수Response 타입의 파라미터를 선언할 수 있습니다. (쿠키와 헤더에 대해 선언하는 것과 유사하게)

그리고 이 임시 응답 객체에서 status_code를 설정할 수 있습니다.

from fastapi import FastAPI, Response, status

app = FastAPI()

tasks = {"foo": "Listen to the Bar Fighters"}


@app.put("/get-or-create-task/{task_id}", status_code=200)
def get_or_create_task(task_id: str, response: Response):
    if task_id not in tasks:
        tasks[task_id] = "This didn't exist before"
        response.status_code = status.HTTP_201_CREATED
    return tasks[task_id]

그리고 평소처럼 원하는 객체(dict, 데이터베이스 모델 등)를 반환할 수 있습니다.

response_model을 선언했다면 반환된 객체는 여전히 필터링되고 변환됩니다.

FastAPI는 이 임시 응답 객체에서 상태 코드(쿠키와 헤더 포함)를 추출하여, response_model로 필터링된 반환 값을 최종 응답에 넣습니다.

또한, 의존성에서도 Response 파라미터를 선언하고 그 안에서 상태 코드를 설정할 수 있습니다. 단, 마지막으로 설정된 상태 코드가 우선 적용된다는 점을 유의하세요.