본문 바로가기
Back-End/Spring MVC Ⅱ

타임리프 - 스프링 통합과 폼: 프로젝트 설정, 타임리프 스프링 통합

by 달의 조각 2022. 6. 2.
이 글은 김영한 님의 스프링 MVC 2편 - 백엔드 웹 개발 활용 기술 강의를 수강하며 정리한 글입니다.

 

스프링 MVC 1편 마지막에 완성했던 상품 관리 프로젝트에 스프링이 지원하는 다양한 기능을 붙인다.
상품 관리 프로젝트를 약간 다듬어서 form-start라는 프로젝트에 넣어 두었다.

 

프로젝트 설정 순서

1. form-start의 폴더 이름을 form로 변경
2. 프로젝트 임포트
    File → Open 해당 프로젝트의 build.gradle 선택 Open as Project 선택
3. ItemServiceApplication.main()을 실행해서 프로젝트가 정상 수행되는지 확인

 


 

타임리프의 2가지 메뉴얼

˙ 기본 메뉴얼
˙ 스프링 통합 메뉴얼

타임리프는 스프링 없이도 동작하지만, 스프링과 통합을 위한 다양한 기능을 편리하게 제공

 

스프링 통합으로 추가되는 기능들

˙ 스프링의 SpringEL 문법 통합

˙ ${@myBean.doSomething()}처럼 스프링 빈 호출 지원

˙ 편리한 폼 관리를 위한 추가 속성
  ˙ th:object (기능 강화, 폼 커맨드 객체 선택)
  ˙ th:field , th:errors , th:errorclass

˙ 폼 컴포넌트 기능
  ˙ checkbox, radio button, List 등을 편리하게 사용할 수 있는 기능 지원

˙ 스프링의 메시지, 국제화 기능의 편리한 통합

˙ 스프링의 검증, 오류 처리 통합

˙ 스프링의 변환 서비스 통합(ConversionService)

 

설정 방법

타임리프 템플릿 엔진을 스프링 빈에 등록하고, 타임리프용 뷰 리졸버를 스프링 빈으로 등록하는 방법

https://www.thymeleaf.org/doc/tutorials/3.0/thymeleafspring.html#the-springstandard-dialect https://www.thymeleaf.org/doc/tutorials/3.0/thymeleafspring.html#views-and-view-resolvers

스프링 부트는 이런 부분을 모두 자동화 해 준다.

build.gradle에 아래 코드를 넣으면 Gradle은 타임리프와 관련된 라이브러리를 다운로드 받고,
스프링 부트는 앞서 설명한 타임리프와 관련된 설정용 스프링 빈을 자동으로 등록

implementation 'org.springframework.boot:spring-boot-starter-thymeleaf'

 

타임리프 관련 설정을 변경하고 싶으면 다음을 참고해서 application.properties에 추가하면 된다.

 

스프링 부트가 제공하는 타임리프 설정, thymeleaf 검색 필요

https://docs.spring.io/spring-boot/docs/current/reference/html/appendix-application-properties.html#common-application-properties-templatin

댓글