250x250
Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- objecterror
- 서블릿
- @configuration
- java
- 오버라이딩
- http 메시지 컨버터
- 싱글톤
- 테스트코드
- 코드트리
- 김영한
- 코딩테스트
- HttpServletResponse
- ocp
- DI
- 프록시
- 추상클래스
- 스프링컨테이너
- 인터페이스
- 의존관계
- 코드트리조별과제
- 참조변수
- fielderror
- 다형성
- 티스토리챌린지
- JSON
- 백준
- html form
- 스프링
- equals()
- 오블완
Archives
- Today
- Total
minOS
스프링 MVC 기본 기능 - 응답(1) 본문
728x90
HTTP 응답 - 정적 리소스, 뷰 템플릿
스프링(서버)에서 응답 데이터를 만드는 방법은 크게 3가지이다.
1) 정적 리소스
예) 웹 브라우저에 정적인 HTML, css, js를 제공할 때는, 정적 리소스를 사용한다.
2) 뷰 템플릿 사용
예) 웹 브라우저에 동적인 HTML을 제공할 때는 뷰 템플릿을 사용한다.
3) HTTP 메시지 사용
예) HTTP API를 제공하는 경우에는 HTML이 아니라 데이터를 전달해야 하므로, HTTP 메시지 바디에 JSON 같은 형식으로 데이터를 실어 보낸다.
정적 리소스
스프링 부트는 클래스패스의 다음 디렉토리에 있는 정적 리소스를 제공한다.
/static , /public , /resources ,/META-INF/resources
src/main/resources` 는 리소스를 보관하는 곳이고, 또 클래스패스의 시작 경로이다. 따라서 다음 디렉토리에 리소스를 넣어두면 스프링 부트가 정적 리소스로 서비스를 제공한다.
정적 리소스 경로 : src/main/resources/static
다음 경로에 파일이 들어있으면 `src/main/resources/static/basic/hello-form.html`
웹 브라우저에서 다음과 같이 실행하면 된다. `http://localhost:8080/basic/hello-form.html`
뷰 템플릿
뷰 템플릿을 거쳐서 HTML이 생성되고, 뷰가 응답을 만들어서 전달한다. 일반적으로 HTML을 동적으로 생성하는 용도로 사용하지만, 다른 것들도 가능하다. 뷰 템플릿이 만들 수 있는 것이라면 뭐든지 가능하다. 스프링 부트는 기본 뷰 템플릿 경로를 제공한다.
`src/main/resources/templates`
<!DOCTYPE html> <html xmlns:th="http://www.thymeleaf.org"> <head> <meta charset="UTF-8"> <title>Title</title> </head> <body> <p th:text="${data}">empty</p> </body> </html>
@RequestMapping("/response-view-v1") public ModelAndView responseViewV1(){ ModelAndView modelAndView = new ModelAndView("response/hello") .addObject("data","hello!"); return modelAndView; }
@RequestMapping("/response-view-v2") public String responseViewV2(Model model){ model.addAttribute("data","오랜만"); return "response/hello"; }
@RequestMapping("/response/hello") public void responseViewV3(Model model){ model.addAttribute("data","bye"); }
뷰 템플릿으로 응답하는 방법
1)String을 반환하는 경우 - View or HTTP 메시지
@ResponseBody` 가 없으면 `response/hello로 뷰 리졸버가 실행되어서 뷰를 찾고, 렌더링 한다. `@ResponseBody` 가 있으면 뷰 리졸버를 실행하지 않고, HTTP 메시지 바디에 직접 `response/hello` 라는 문자가 입력된다.
2) Void를 반환하는 경우
`@Controller` 를 사용하고, `HttpServletResponse` , `OutputStream(Writer)` 같은 HTTP 메시지 바 디를 처리하는 파라미터가 없으면 요청 URL을 참고해서 논리 뷰 이름으로 사용
요청 URL: `/response/hello`
실행: `templates/response/hello.html`
참고로 이 방식은 명시성이 너무 떨어지고 이렇게 딱 맞는 경우도 많이 없어서, 권장하지 않는다
HTTP 메시지
`@ResponseBody` , `HttpEntity` 를 사용하면, 뷰 템플릿을 사용하는 것이 아니라, HTTP 메시지 바디에 직접 응답
데이터를 출력할 수 있다.
728x90
'TIL > 김영한의 스프링 MVC 1편 - 백엔드 웹 개발 핵심 기술' 카테고리의 다른 글
스프링 MVC 기본 기능 - HTTP 메세지 컨버터 (0) | 2024.08.02 |
---|---|
스프링 MVC 기본 기능 - 응답(2) (0) | 2024.08.01 |
스프링 MVC 기본 기능 - HTTP 요청 메시지(2) (0) | 2024.07.30 |
스프링 MVC 기본 기능 - HTTP 요청 메시지(1) (0) | 2024.07.29 |
스프링 MVC 기본 기능 - @RequestParam,@ModelAttribute (0) | 2024.07.28 |