springboot~手動加載thymeleaf模版

thymeleaf在spring-mvc時代很是盛行,與freemaker組成了兩大模版引擎,而進行springboot之後,很多項目都採用前後分離的模式,這使得模板引擎關注度少了;而在一些場景下,使用模板引擎還是有着不可替代的優勢的,比如email模板,我們會把html模版文件和後端代碼放到一個項目,這樣部署更方便,組件的內聚性更強。

  • 定義自己的模塊引擎
/**
 * 定義一個目錄爲資源根目錄的引擎
 * @author lind
 * @date 2022/8/18 9:04
 * @since 1.0.0
 */
@Configuration
public class EngConfig {
    @Bean("rootEngine")
    public SpringTemplateEngine springTemplateEngine() {
        SpringTemplateEngine templateEngine = new SpringTemplateEngine();
        templateEngine.addTemplateResolver(htmlTemplateResolver());
        return templateEngine;
    }
    @Bean
    public SpringResourceTemplateResolver htmlTemplateResolver(){
        SpringResourceTemplateResolver templateResolver = new SpringResourceTemplateResolver();
        templateResolver.setPrefix("classpath:/");
        templateResolver.setSuffix(".html");
        templateResolver.setTemplateMode(TemplateMode.HTML);
        templateResolver.setCharacterEncoding(StandardCharsets.UTF_8.name());
        return templateResolver;
    }
}
  • 在需要使用email的地方,直接通過SpringTemplateEngine的process方法來渲染html模板
@RestController
@RequiredArgsConstructor
public class MailController {
    private final SpringTemplateEngine springTemplateEngine;
    private String template = "META-INF/spring/mail.html";

    /**
     * 發送email.
     *
     * @return
     */
    @GetMapping("/mail/send")
    public String send() {
        Context ctx = new Context();
        ctx.setVariable("message", "zhangsan");
        return springTemplateEngine.process(this.template, ctx);
    }
}
  • mail.html很簡單,裏面有個message的變量,由上面的後端代碼傳入
<html xmlns:th="http://www.thymeleaf.org">
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/>

</head>
<body>
<h2 th:text="${message}" />
</body>
</html>

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章