[Spring MVC] #4 기본 기능 (4) HTTP 응답

Jaeyoo (유재형)·2022년 2월 14일
0

SpringMVC

목록 보기
12/12
post-thumbnail
post-custom-banner

HTTP 응답을 만드는 방법은 세가지가 있다.

  1. 정적 리소스 : 정적인 HTML, CSS 등등
  2. 뷰 템플릿 사용 : 동적인 HTML
  3. HTTP 메시지 사용 : HTTP 메시지 바디에 JSON 같은 형식으로 데이터를 보낸다.

정적리소스, 뷰 템플릿


정적 리소스

  • src/main/resources 하위에 /static, /public, /META-INF/resources 안에 넣으면 된다.
  • 따라서 다음 디렉토리에 리소스를 넣어두면 스프링 부트가 정적 리소스로 서비스를 제공

뷰 템플릿

  • 뷰 템플릿을 거쳐서 HTML이 생성되고 뷰가 응답을 만들어서 전달한다.
  • 뷰 템플릿 경로 src/main/resources/templates

ModelAndView 반환

@Controller
public class ResponseViewController {

      @RequestMapping("/response-view-v1")
      public ModelAndView responseViewV1() {
          ModelAndView mav = new ModelAndView("response/hello")
                  .addObject("data", "hello!");
    return mav;
}
  • ViewName과 model을 ModelAndView에 담아서 반환

String 반환

@RequestMapping("/response-view-v2")
public String responseViewV2(Model model) {
    model.addAttribute("data", "hello!!");
    return "response/hello";
}
  • @ResponseBody가 없으므로 string이 뷰의 논리적인 이름이된다.
  • ModelAndView를 생성하지않고 model을 받아서 넣어준다.

void 반환

@RequestMapping("/response/hello")
public void responseViewV3(Model model) {
    model.addAttribute("data", "hello!!");
}
  • 뷰이름을 없애고 requestMapping 주소를 html이 있는주소로 변경
  • 권장하지않음

HTTP API, 메시지 바디에 직접 입력


HttpServletResponse

@GetMapping("/response-body-string-v1")
public void responseBodyV1(HttpServletResponse response) throws IOException {
        response.getWriter().write("ok");
}
  • HttpServletResponse 객체를 통해서 HTTP 메시지 바디에 직접 ok 응답 메시지를 전달

ResponseEntity

@GetMapping("/response-body-string-v2")
    public ResponseEntity<String> responseBodyV2() {
        return new ResponseEntity<>("ok", HttpStatus.OK);
}
  • ResponseEntity 엔티티는 HttpEntity 를 상속 받음
  • HttpEntity는 HTTP 메시지의 헤더, 바디 정보를 가지고 있다.
  • ResponseEntity 는 여기에 더해서 HTTP 응답 코드를 설정할 수 있다.

@ResponseBody

@ResponseBody
@GetMapping("/response-body-string-v3")
public String responseBodyV3() {
        return "ok";
}
  • @ResponseBody 를 사용하면 view를 사용하지 않고, HTTP 메시지 컨버터를 통해서 HTTP 메시지를 직접 입력할 수 있다.
  • ResponseEntity 도 동일한 방식으로 동작한다.

JSON


ResponseEntity 반환

@GetMapping("/response-body-json-v1")
public ResponseEntity<HelloData> responseBodyJsonV1() {
        HelloData helloData = new HelloData();
        helloData.setUsername("userA");
        helloData.setAge(20);
        
        return new ResponseEntity<>(helloData, HttpStatus.OK);
}
  • ResponseEntity 를 반환.
  • HTTP 메시지 컨버터를 통해서 JSON 형식으로 변환되어서 반환된다.

@ResponseBody

@ResponseStatus(HttpStatus.OK)
@ResponseBody
@GetMapping("/response-body-json-v2")
public HelloData responseBodyJsonV2() {
          HelloData helloData = new HelloData();
          helloData.setUsername("userA");
          helloData.setAge(20);
          
          return helloData;
      }
  • ResponseEntity와 다르게 @ResponseBody 를 사용하면 응답코드 설정하기 까다로움.
  • @ResponseStatus(HttpStatus.OK) 애노테이션을 사용하면 응답 코드도 설정할 수 있다
profile
기록과 반복
post-custom-banner

0개의 댓글