Vert.x - SpringBoot 整合 vertx 使用 thymeleaf、freemarker 模板引擎

article/2025/8/21 3:51:23

一、模板引擎

在 SpringMVC 项目中使用模板引擎,使用较多的应该是 thymeleaffreemarker 了吧,虽然现在前后端分离的浪潮已经席卷而来,但对于 SEO 或者 页面静态话来说,后端的模板引擎还是具有一定的作用力。本篇文章继续上篇文章中搭建的 SpringBoot 项目中继续讲解,因此在看本篇文章之前,确保已经搭建了上篇文章的项目。

下面是上篇文章的地址:

https://blog.csdn.net/qq_43692950/article/details/124076793

下面分别对 thymeleaffreemarker 的使用进行实践。

二、thymeleaf 模板引擎

首先引入 thymeleaf 模板引擎的依赖:

<dependency><groupId>io.vertx</groupId><artifactId>vertx-web-templ-thymeleaf</artifactId><version>${vertx-version}</version><classifier>shaded</classifier>
</dependency>

然后声明 thymeleaf 引擎:

@Bean
public ThymeleafTemplateEngine thymeleafTemplateEngine(Vertx vertx){return ThymeleafTemplateEngine.create(vertx);
}

在统一的 BaseVerticle 中声明 引擎:

@Component
public abstract class BaseVerticle extends AbstractVerticle {@Autowiredpublic Router router;@Autowiredpublic ThymeleafTemplateEngine thymeleafTemplateEngine;
}

下面在resources 下新建 templates 目录,新建 index.html 文件:

<!DOCTYPE html SYSTEM "http://www.thymeleaf.org/dtd/xhtml1-strict-thymeleaf-4.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xmlns:th="http://www.thymeleaf.org">
<head><title>test</title><meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/>
</head>
<body>
<h1 th:text="'姓名:'+ ${name}"></h1>
<h1 th:text="'年龄:' + ${age}"></h1>
<h2>列表</h2>
<ul><li th:each="item:${list}" th:text="${item}"></li>
</ul>
</body>
</html>

编写Verticle,渲染上面的 index.html

@Component
public class ThymeleafVerticle extends BaseVerticle {@Overridepublic void start() throws Exception {router.get("/thymeleaf").handler(this::thymeleaf);}private void thymeleaf(RoutingContext ctx) {List<String> list = new ArrayList<>();for (int i = 1; i <= 10; i++) {list.add("序号:" + i);}JsonObject data = new JsonObject().put("name", "小毕超").put("age", "18").put("list", list);thymeleafTemplateEngine.render(data, "templates/index.html", res -> {if (res.succeeded()) {ctx.response().putHeader("Content-Type", "text/html; charset=UTF-8").end(res.result());} else {ctx.fail(res.cause());}});}
}

下面启动 SpringBoot ,访问 http://localhost:8080/thymeleaf
在这里插入图片描述

三、freemarker 模板引擎

freemarker 模板引擎使用起来和 thymeleaf 基本相同:
引入 freemarker 模板引擎的依赖:

<dependency><groupId>io.vertx</groupId><artifactId>vertx-web-templ-freemarker</artifactId><version>${vertx-version}</version><classifier>shaded</classifier>
</dependency>

然后声明 freemarker 引擎:

@Bean
public FreeMarkerTemplateEngine freeMarkerTemplateEngine(Vertx vertx){return FreeMarkerTemplateEngine.create(vertx);
}

在统一的 BaseVerticle 中声明 引擎:

@Component
public abstract class BaseVerticle extends AbstractVerticle {@Autowiredpublic Router router;@Autowiredpublic FreeMarkerTemplateEngine freeMarkerTemplateEngine;@Autowiredpublic ThymeleafTemplateEngine thymeleafTemplateEngine;
}

下面在resources 下新建 templates 目录,新建 index.ftl 文件:

<!DOCTYPE html>
<html >
<head><title>test</title><meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/>
</head>
<body>
<h1>${name}</h1>
<h1>${age}</h1>
<h2>列表</h2><ul><#list list as item><li>${item}</li></#list>
</ul></body>
</html>

编写Verticle,渲染上面的 index.html

@Component
public class FreemarkerVerticle extends BaseVerticle {@Overridepublic void start() throws Exception {router.get("/freemarker").handler(this::thymeleaf);}private void thymeleaf(RoutingContext ctx) {List<String> list = new ArrayList<>();for (int i = 1; i <= 10; i++) {list.add("序号:" + i);}JsonObject data = new JsonObject().put("name", "小毕超").put("age", "18").put("list", list);freeMarkerTemplateEngine.render(data, "templates/index.ftl", res -> {if (res.succeeded()) {ctx.response().putHeader("Content-Type", "text/html;charset=UTF-8").end(res.result());} else {res.cause().printStackTrace();ctx.fail(res.cause());}});}
}

下面启动 SpringBoot ,访问 http://localhost:8080/freemarker
在这里插入图片描述
在这里插入图片描述
喜欢的小伙伴可以关注我的个人微信公众号,获取更多学习资料!


http://chatgpt.dhexx.cn/article/gZiJp9bn.shtml

相关文章

Vert.x - SpringBoot 整合 vertx

一、vertx 前面的文章讲解了 vertx 的简介及 vertx-web 的路由&#xff0c;看过的小伙伴应该对 vertx 有了一定的了解&#xff0c;从前面的演示来看&#xff0c;都是单独使用的 vertx &#xff0c;对于目前的后端来说 SpringBoot 可是一个非常火热的框架&#xff0c;那如果将 …

Vert.x - vertx-web 路由讲解总结

一、vertx-web 上篇文章我们对 vertx 进行了简单的介绍&#xff0c;并使用 vertx-web 实践了 restFul 接口的书写&#xff0c;本篇文章接着上篇继续讲解 vertx-web 的路由。 下面是上篇文章的地址&#xff1a; https://blog.csdn.net/qq_43692950/article/details/123955368 …

vertx的http服务实现分布式session

vetrx是基于netty封装的java网络编程框架&#xff0c;比netty开发较为简单&#xff0c;在其基础上提供很多有用功能&#xff0c;能在较短的时间内开发一个http服务器&#xff0c;或其他网络服务。今天我们展示下如何为vertx开发http网关实现分布式session,实现参考spring sessi…

Vert.x入门1 —— 《基础概念》

一、什么是Vertx Vert.x 在JVM上构建响应式应用程序的工具包&#xff0c;Vert.x不是框架而是工具包。Vert.x基于Netty项目&#xff0c;该项目是JVM的高性能异步网络库。 此描述中有三个重要点&#xff1a;工具包&#xff0c;响应式和“在JVM上”。 首先&#xff0c;Vert.x是…

Vertx快速入门参考

Vertx学习 什么是vertx&#xff1f; Vert.x最大的特点就在于异步&#xff08;底层基于Netty&#xff09;&#xff0c;通过事件循环&#xff08;EventLoop&#xff09;来调起存储在异步任务队列&#xff08;CallBackQueue&#xff09;中的任务&#xff0c;大大降低了传统阻塞模…

Vertx入门学习(含代码)

Vertx入门学习 一、Vertx是什么&#xff1f;二、Vertx基本概念三、Vertx能干什么&#xff1f;四、Vertx的技术体系五、快速体验&#xff1a;搭建一个简单的Vertx项目并输出Hello World六、单元测试总结 一、Vertx是什么&#xff1f; github: https://github.com/vert-x3 官网&…

Vert.x(vertx) 简明介绍

摘要 Vert.x最大的特点就在于异步&#xff08;底层基于Netty&#xff09;&#xff0c;通过事件循环&#xff08;EventLoop&#xff09;来调起存储在异步任务队列&#xff08;CallBackQueue&#xff09;中的任务&#xff0c;大大降低了传统阻塞模型中线程对于操作系统的开销。因…

Vertx学习一:这玩意是到底是个啥

Vertx&#xff0c;融合Java、Ruby、Python等语言的高性能架构&#xff0c;架构师必读 原文链接&#xff1a; http://www.360doc.com/content/18/0203/14/39530679_727432611.shtml 目录&#xff1a; 一、Vert.x简介 二、Vert.x原理解析 三、Vert牛刀小试 四、Vert应用实践 五…

【java】vertx从入门到放弃——入门(四)Codec

什么是Codec&#xff1f;概念这个玩意我是真不想说&#xff0c;毕竟我没有找到具体的概念&#xff0c;我自己大致的理解就是&#xff0c;用EventBus传输类的时候&#xff0c;对这个类进行序列化和反序列化的东西&#xff0c;因为vertx使用json进行传输&#xff0c;所以这个玩意…

Android thinker

国家虽安&#xff0c;忘战必危&#xff0c; Android虽爽&#xff0c;不学则忙&#xff0c;老夫纵横江湖数十载&#xff0c;深谙世事之难料&#xff0c;顾。。 ok&#xff0c;ok 不装比了&#xff0c;进入正题&#xff0c;今天要讲的是Android 热修之 thinker。 在研究这个之前…

ESP32-CAM AI THINKER 引脚排列:GPIO 用法说明

ESP32-CAM 是一款开发板,带有一个 ESP32-S 芯片、一个 OV2640 摄像头、microSD 卡插槽和几个用于连接外设的 GPIO。在本指南中,我们将介绍 ESP32-CAM GPIO 以及如何使用它们。 引脚排列图 下图显示了 ESP32-CAM AI-Thinker 的引脚排列图。 电路原理示意图 下图显示了 ESP…

Thinkpad 各系列简介

ThinkPad 各系列简介 如果提到商务笔记本&#xff0c;大家一定会想到凭借坚固和可靠的特性在业界享有很高声誉ThinkPad笔记本电脑&#xff0c;以及ThinkPad那经典的键盘红点设计和纯黑低调的外表。 在这里我就简单介绍一下ThinkPad的各系列产品。 Thinkpad名称来历 “ThinkP…

python thinker canvas create_arc 使用详解

版权声明&#xff1a;本文为博主原创文章&#xff0c;遵循 CC 4.0 BY-SA 版权协议&#xff0c;转载请附上原文出处链接和本声明。 本文链接&#xff1a;https://blog.csdn.net/A757291228/article/details/106739556 ———————————————— 版权声明&#xff1a;本文…

二、让界面动起来,Python基于thinker实现的简单的俄罗斯方块小游戏

文章目录 界面动起来定时刷新页面移动俄罗斯方块 界面动起来 **功能&#xff1a;**如何让方块「动起来」? 分析过程&#xff1a; 要想让方块动起来&#xff0c;需要实现以下两点&#xff1a; 定时刷新页面移动页面内部的俄罗斯方块 定时刷新页面 实现定时刷新页面&#xff…

三、生成随机方块,Python基于thinker实现的简单的俄罗斯方块小游戏

文章目录 生成第一步&#xff1a;随机生成方块对象第二步&#xff1a;修改游戏运行方法 固定第一步&#xff1a;记录固定的方块第二步&#xff1a;修改check_move方法 左右移动第一步&#xff1a;左右移动方块第二步&#xff1a;绑定键盘 旋转第一步&#xff1a;添加旋转方法第…

【G-thinker】G-thinker部分源码解析

一、main 子图匹配程序run.cpp中主要使用到worker.h和comper.h分别对应线程和进程单位&#xff0c;接下来我们从main函数入手解析源码 从主函数可以看到&#xff0c;子图匹配程序中GMatchWorker继承了worker&#xff0c;主函数声明了workerparams并且传入了路径和线程参数&am…

python用thinker库制作一个进制转换器(可打包exe)

进制类型分为&#xff1a; 二进制 字母B表示 八进制 字母O表示 十进制 字母D表示 十六机制 字母H表示 进制转换之间很麻烦&#xff0c;还得计算&#xff0c;如果可以做一个进制转换器多nice&#xff0c;其实也不难&#xff0c;就利用一个tkinter库就能制作&#xff0c;废话不多…

Thinker Board 2开发板上使用奥比中光 astra 深度相机

Thinker Board 2 国产开发板 arm架构 上使用奥比中光 astra 深度相机 准备工作 1、下载astraSDK 选择linux_arm 下载 https://developer.orbbec.com.cn/download.html?id53 2、下载openNI https://dl.orbbec3d.com/dist/openni2/OpenNI_2.3.0.66.zip 开始安装 1、安装fre…

think

我167&#xff0c;97斤&#xff0c;胸d&#xff0c;腰很细&#xff0c;反手轻松摸肚脐那种&#xff0c;骨架小&#xff0c;总结就是身高刚好人瘦胸大屁股大腿细腰细肤白。走路腰杆能挺到天上&#xff0c;气质挺好。漂亮女生太多了&#xff0c;想取胜只能从气质下手了。脸呢&…

Python基于thinker实现的简单的俄罗斯方块小游戏源代码:一、搭建界面

文章目录 一、搭建界面搭建基础窗体第一步&#xff1a;创建画板大小第二步&#xff1a;在画板上作画 绘制俄罗斯方块第一步&#xff1a;绘制o形俄罗斯方块第二步&#xff1a;绘制其他形状方块 记录俄罗斯方块小游戏的游戏思路和过程 一、搭建界面 **目标&#xff1a;**搭建基础…