You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

1.7 KiB

응답 - 상태 코드 변경

기본 응답 상태 코드 설정{.internal-link target=_blank}이 가능하다는 걸 이미 알고 계실 겁니다.

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

사용 예

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

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

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

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

Response 파라미터 사용하기

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

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

{* ../../docs_src/response_change_status_code/tutorial001.py hl[1,9,12] *}

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

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

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

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