inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

스프링 MVC 1편 - 백엔드 웹 개발 핵심 기술

HTTP 요청 메시지 - JSON

response.getWriter().write와 그냥 return ok

480

김철준

작성한 질문수 45

0

학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.

1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)

질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? 예
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? 예
3. 질문 잘하기 메뉴얼을 읽어보셨나요? 예

[질문 내용]
여기에 질문 내용을 남겨주세요.

 

v1에서는 response.getWriter().write("ok");, v2에서는 return "ok";을 해주시는데 이유가 뭘까요??

 

@PostMapping("/request-body-json-v1")
public void requestBodyJsonV1(HttpServletRequest request, HttpServletResponse response) throws IOException {
    ServletInputStream inputStream = request.getInputStream();
    String messageBody = StreamUtils.copyToString(inputStream, StandardCharsets.UTF_8);

    log.info("messagebody={}", messageBody);
    HelloData helloData = objectMapper.readValue(messageBody, HelloData.class);
    log.info("username={}, age={}", helloData.getUsername(), helloData.getAge());

    response.getWriter().write("ok");
}

@ResponseBody
@PostMapping("/request-body-json-v2")
public String requestBodyJsonV2(@RequestBody String messageBody) throws IOException {


    log.info("messagebody={}", messageBody);
    HelloData helloData = objectMapper.readValue(messageBody, HelloData.class);
    log.info("username={}, age={}", helloData.getUsername(), helloData.getAge());

    return "ok";
}

 

spring mvc

답변 1

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴입니다.

김철준님의 질문은 response.getWriter().write("ok")return "ok" 사용 시의 차이점에 대해 관심이 있으신 것 같습니다. 이 두 방식은 스프링 MVC에서 클라이언트에게 HTTP 응답을 반환하는 방법에 있어 핵심적인 차이를 갖습니다.

response.getWriter().write("ok") 방식은 HttpServletRequestHttpServletResponse 객체를 직접 사용하여 응답을 처리합니다. 여기서는 HttpServletResponsegetWriter() 메소드를 통해 PrintWriter 객체를 얻고, 이를 통해 직접적으로 HTTP 응답 본문에 문자열을 쓰게 됩니다. 이 방식은 스프링의 @Controller 어노테이션을 사용한 매핑 메소드에서 주로 볼 수 있으며, 근본적으로는 서블릿 API의 저수준 기능을 활용하는 것입니다.

반면, return "ok" 방식에서는 스프링의 @ResponseBody 어노테이션이 사용됩니다. 이 경우 스프링은 메소드가 반환하는 값을 HTTP 응답 본문으로 직접 매핑하라는 지시를 받게 됩니다. 여기서 "ok" 문자열은 HTTP 응답 본문으로 직접 쓰이게 되며, 이 과정에서 스프링은 내부에서 HttpMessageConverter를 사용하여 반환 값을 적절한 형식으로 변환하고 클라이언트에게 전달합니다. 이 방식은 데이터를 반환하는 REST API를 구현할 때 널리 사용됩니다.

두 방식의 선택은 상황에 따라 달라질 수 있습니다. 직접적으로 HttpServletResponse를 사용하는 방식은 더 많은 제어를 필요로 하는 비교적 복잡한 상황에서 유용할 수 있지만, 일반적인 경우 @ResponseBody를 사용하는 것이 더 간결하고 편리하며, 스프링의 강력한 데이터 바인딩 기능을 최대한 활용할 수 있습니다.

비슷한 주제에 대해 다루는 기존 답변 링크는 다음과 같습니다:

  • /request-param-v1 질문있습니다.: 이 질문에서 @Controller@RestController의 차이점 및 @ResponseBody의 역할에 대해 설명하고 있으멀로, response.getWriter().write("ok")return "ok" 사용 시의 차이점에 대한 이해를 돕는 데 유용할 것입니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

servlet과 container에 대한 질문입니다

0

21

1

api를 어느 컨트롤러에 작성해야하는지는 어떤 기준으로 해야하나요?

0

62

1

jsp 의존성 수정 요청

0

75

2

요즘 웹 서버가 주로 사용되는 이유는 SPA 구조 때문일까요 ?

0

142

1

save() 메서드 문의

0

65

1

절대 경로로 templates/basic 하위 파일 열면 css 적용 안되는 현상

0

99

1

request-body-json

0

83

2

MVC 패턴의 적용 단위

0

94

1

RequestMapping을 이용한 핸들러, 어댑터

0

118

2

save 후 결과화면

0

86

2

jsp를 이용한 view

0

97

1

application.properties에 debug 추가해도 결과가 똑같습니다.

0

175

1

수업 코드 제공 관련 문의

0

97

2

RequestMappingHandlerAdapter의 Controller 호출 과정

0

98

3

파일 오픈 시

0

68

1

스프링 배치 관련

0

77

1

@RequestParam의 defaultValue가 blank 값도 처리하는 지 여부

0

112

1

postman으로 /request-body-json-v1 호출시 500 error

0

94

1

프론트엔드와 백엔드의 mvc, rest api에 대한 질문

0

77

1

모델의 역할과 계층 분리에 대한 이해 차이 + 추가질문

0

111

1

console log 출력 관련 질문입니다.

0

73

1

애플리케이션이 실행 되지 않습니다 ㅠㅠㅠ

0

138

1

html 변경하는 부분 적용 문제

0

100

1

한글 깨짐

0

76

2