FastAPI 애플리케이션을 개발할 때 JSON 형식 데이터 반환의 미묘한 차이를 이해하는 것이 중요합니다. 이를 위해서는 FastAPI의 내부 작동 방식을 자세히 살펴보고 JSON 직렬화가 수행하는 역할을 이해해야 합니다.
문제의 핵심은 json.dumps() 사용에 있습니다. 객체를 반환하기 전에 객체를 직렬화합니다. 이 접근 방식은 논리적으로 보일 수 있지만 FastAPI가 응답 생성 중에 반환 값을 자동으로 JSON으로 인코딩하므로 중복 직렬화가 도입됩니다. 이로 인해 깔끔한 형식의 dict가 아닌 JSON 데이터의 문자열 표현이 잘못된 것처럼 보입니다.
이 문제를 해결하려면 FastAPI가 JSON 직렬화 프로세스를 처리하도록 허용해야 합니다. 이는 데이터 객체(dicts, list 등)를 직접 반환하여 달성할 수 있습니다. FastAPI는 jsonable_encoder를 사용하여 이를 JSON 호환 데이터로 원활하게 변환하고 JSONResponse로 래핑합니다. 결과 응답에는 원하는 JSON 형식을 보장하는 애플리케이션/json 인코딩 데이터가 포함됩니다.
예상대로 데이터 객체를 반환합니다. :
@app.get('/') async def main(): return d
뒤에서 FastAPI는 JSONResponse를 사용하여 dict(d)를 직렬화하고 인코딩합니다. with json.dumps().
응답을 정밀하게 제어해야 하는 경우 응답 개체를 직접 활용하세요.
@app.get('/') async def main(): return Response(content=json.dumps(d, indent=4, default=str), media_type='application/json')
이것은 접근 방식은 media_type(예: 'application/json')에 대한 자유를 부여합니다.
참고: json.dumps()(str)의 기본 인수는 날짜/시간 객체의 직렬화를 허용합니다. 들여쓰기를 전달하면 JSON 출력의 형식을 제어할 수 있습니다.
위 내용은 FastAPI 애플리케이션에서 JSON 형식 데이터를 효율적으로 반환하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!