[Spring] @RestController
Spring에서 컨트롤러를 등록하는 방법에는 두가지가 있다.
@Controller와 @RestController.
@Controller는 주로 View를 반환한다. 하지만 @Controller에 @ResponseBody를 붙이면 view가 아닌 xml, json과 같은 데이터를 반환할 수 있다. (참고 : 2021.04.01 - [spring] - Controller에서 데이터 반환하기)
매번 @ResponseBody를 붙이는 것은 번거로우니 Spring 4.0부터는 @RestController를 지원하기 시작했다.
@RestController
@Controller + @ResponseBody
Spring 4.0부터 사용가능한 어노테이션으로 @Controller에 @ResponseBody가 결합된 어노테이션이다.
@RestController의 모든 메소드에서 리턴되는 값은 MessageConverter에서 변환되어 HTTP Response Body에 쓰여진다.
[ @Controller를 사용하던 기존 코드 ]
@Controller
public class SampleController{
@GetMapping("/example")
@ResponseBody
public SampleDTO example() {
SampleDTO dto = new SampleDTO();
dto.setAge(24);
dto.setName("mangdo");
return dto; //스프링이 자동으로 JSON타입으로 객체를 반환해서 전달한다.
}
}
[ @RestController를 사용하는 수정 코드 ]
@RestController
public class SampleController{
@GetMapping("/example")
public SampleDTO example() {
SampleDTO dto = new SampleDTO();
dto.setAge(24);
dto.setName("mangdo");
return dto; //스프링이 자동으로 JSON타입으로 객체를 반환해서 전달한다.
}
}
@RestController 사용예
1. 반환 값으로 텍스트 컨텐츠를 반환한다.
반환 값이 바로 response body에 쓰여진다.
@RequestMapping("/rest")
public String rest1() {
return "text content";
}
2. 컨텐츠 형식을 지정한다.
consumes는 받는 컨텐츠 형식이고, produces는 응답하는 컨텐츠 형식이다.
org.springframework.http.MediaType 클래스에 콘텐츠 형식의 상수가 정의되어 있으니 이것을 이용하는 것이 좋다.
@PostMapping(value="/new", consumes="application/json", produces= {MediaType.TEXT_PLAIN_VALUE})
public ResponseEntity<String> create(@RequestBody ProductReviewVO vo){
log.info("ReviewVO : " + vo);
return service.register(vo)==1?
new ResponseEntity<>("success",HttpStatus.OK) :
new ResponseEntity<>(HttpStatus.INTERNAL_SERVER_ERROR);
}
3. HTTP 상태 및 응답헤더를 지정해준다.
HTTP 상태와 같은 컨텐츠 형식 이외의 응답 헤더를 지정해주고 싶다면 반환값을 ResponseEntity한다.
@PostMapping(value="/new", consumes="application/json", produces= {MediaType.TEXT_PLAIN_VALUE})
public ResponseEntity<String> create(@RequestBody ProductReviewVO vo){
log.info("ReviewVO : " + vo);
return service.register(vo)==1?
new ResponseEntity<>("success",HttpStatus.OK) :
new ResponseEntity<>(HttpStatus.INTERNAL_SERVER_ERROR);
}
4. JSON 반환
반환값을 임의의 클래스라면 springMVC가 Jackson을 사용하여 json으로 변경하여 반환해준다.
@GetMapping("/quickView")
public ProductVO getQuickView(Long product_id) {
log.info("quick View data, " + product_id);
return service.getQuickView(product_id);
}