返回介绍

19.3.2 使用 Thymeleaf 构建 Email 消息

发布于 2024-08-17 00:45:49 字数 2279 浏览 0 评论 0 收藏 0

如我们第6章所讨论的那样,Thymeleaf是一种很有吸引力的HTML模板引擎,因为它能够创建WYSIWYG的模板。与JSP和Velocity不同,Thymeleaf模板不包含任何特殊的标签库和特有的标签。这样模板设计师在工作的时候,能够使用任意他们所喜欢的HTML工具,而不必担心某个工具无法处理特定的标签。

当我们将Email模板转换为Thymeleaf模板时,Thymeleaf的WYSIWYG特性体现得非常明显:

注意,这里没有任何自定义的标签(在JSP中可能会见到这种情况)。尽管模型属性是通过“${}”标记的,但是它们仅用于属性的值中,不会像Velocity那样用在外边。这种模板可以很容易地在Web浏览器中打开,并且以完整的形式进行展现,不必依赖于Thymeleaf引擎的处理。

使用Thymeleaf来生成和发送Email消息的做法非常类似于Velocity:

这里做的第一件事情就是创建Thymeleaf Context实例,并将模型数据填充进去。这与我们使用Velocity的时候,将模型数据填充到Map中很类似。然后,我们要求Thymeleaf处理模板,通过调用Thymeleaf引擎的process()方法,将上下文中的模型数据合并到模板中。最后,我们将结果形成的文本借助消息helper设置到Email消息中,并使用邮件发送器将消息发送出去。

这看起来很简单。但是Thymeleaf引擎(也就是thymeleaf变量)是从哪里来的呢?

这里的Thymeleaf引擎与我们在第6章构建Web视图时所使用的SpringTemplateEnginebean是相同的。在这里,我们使用构造器注入的方式将其注入到SpitterEmailServiceImpl中:

不过,我们必要要对SpringTemplateEnginebean做一点小修改。在第6章中,它配置为从Servlet上下文中解析模板,而我们的Email模板需要从类路径中解析。所以,除了ServletContextTemplateResolver,还需要一个ClassLoaderTemplateResolver:

就大部分而言,配置ClassLoaderTemplateResolver bean的方式类似于ServletContextTemplateResolver。不过,需要注意,我们将prefix属性设置为“mail/”,这表明它会在类路径根的“mail”目录下开始查找Thymeleaf模板。因此,Email模板文件的名字必须是emailTemplate.html,并且位于类路径根的“mail”目录下。

因为我们现在有两个模板解析器,所以需要使用order属性表明优先使用哪一个。ClassLoaderTemplateResolver的order属性为1,因此我们修改一下ServletContext-TemplateResolver,将其order属性设置为2:

现在,剩下的任务就是修改SpringTemplateEnginebean的配置,让它使用这两个模板解析器:

在此之前,我们只有一个模板解析器,所以可以将其注入到SpringTemplateEngine的templateResolver属性中。但现在我们有了两个模板解析器,所以必须将它们作为Set的成员,然后将这个Set注入到templateResolvers(复数)属性中。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文