HTTP API를 제공하느 경우에는 HTML이 아니라 데이터를 전달해야 하므로, HTTP 메세지 바디에 JSON 같은 형식으로 데이터를 실어 보낸다.
🤞참고 )
HTML이나 뷰 템플릿을 사용해도 HTTP 응답 메세지 바디에 HTML 데이터가 담겨서 전달된다.
여기서 설명하는 내용은 정적 리소스나 뷰 템플릿을 거치지 않고, 직접 HTTP 응답 메세지를 전달하는 경우를 말한다.
경로 : hello.springmvc.basic.response
package hello.springmvc1.basic.response;
import hello.springmvc1.basic.HelloData;
import lombok.extern.slf4j.Slf4j;
import org.springframework.http.HttpLogging;
import org.springframework.http.HttpStatus;
import org.springframework.http.ResponseEntity;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.bind.annotation.ResponseStatus;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.net.http.HttpResponse;
@Slf4j
@Controller
public class ResponseBodyController {
@GetMapping("/response-body-string-v1")
public void responseBodyV1(HttpServletResponse response) throws IOException {
response.getWriter().write("ok");
}
/**
* HttpEntity, ResponseEntity(Http Status 추가)
* @Return
*/
@GetMapping("/response-body-string-v2")
public ResponseEntity<String> responseBodyV2(){
return new ResponseEntity<>("ok", HttpStatus.OK);
}
@ResponseBody
@GetMapping("/response-body-string-v3")
public String responseBodyV3(){
return "ok";
}
@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);
}
@ResponseStatus(HttpStatus.OK)
@ResponseBody
@GetMapping("/response-body-json-v2")
public HelloData responseBodyJsonV2(){
HelloData helloData = new HelloData();
helloData.setUsername("userA");
helloData.setAge(20);
return helloData;
}
}
서블릿을 직접 다룰 때 처럼 HttpServletResponse 객체를 통해서 HTTP 메세지 바디에 직접 ok
응답 메세지를 전달한다.
response.getWriter().write("ok")
ResponseEntity
엔티티는 HttpEntity
를 상속 받는데, HttpEntity는 Http 메세지의 헤더, 바디 정보를 가지고 있다. ResponseEntity
는 여기에 더해서 HTTP 응답 코드를 설정할 수 있다.
HttpStatus.CREATED
로 변경하면 201 응답이 나간다.
@ResponseBody
를 사용하면 view를 사용하지 않고, HTTP 메세지 컨버터를 통해서 HTTP 메세지를 직접 입력할 수 있다.ResponseEntity
도 동일한 방식으로 동작한다.
ResponseEntity
를 반환한다. HTTP 메세지 컨버터를 통해서 JSON 형식으로 변환되어서 반환된다.
ResponseEntity
는 HTTP 응답 코드를 설정할 수 있는데 @ResponseBody
를 사용하면 이런 것을 설정하기 까다롭다.
@ResponseStatus(HttpStatus.OK)
애노테이션을 사용하면 응답 코드도 설정할 수 있따.
물론 애노테이션이기 때문에 응답 코드를 동적으로 변경할 수는 없다. 프로그램 조건에 따라서 동적으로 변경하려면 ResponseEntity
를 사용함녀 된다.
@Controller
대신에 @RestController
애노테이션을 사용하면, 해당 컨트롤러에 모두 @ResponseBody
가 적용되는 효과가 있다. 따라서 뷰 템플릿을 사용하는 것이 아니라, HTTP 메세지 바디에 직접 데이터를 입력한다. 이름 그대로 Rest API(HTTP API)를 만들 때 사용하는 컨트롤러이다.
참고로 @ReponseBody
는 클래스 레벨에 두면 전체 메서드에 적용되는데, @RestController
애노테이션 안에 @ResponseBody
가 적용되어 있다.