以简单的例子从头开始建spring boot web多模块项目(五)-thymeleaf引擎

news2025/1/22 21:53:03

继续向里面加,这次是引入thymeleaf渲染引擎。
使用这个引擎的很多,主要是以下几个优点:

  1. Thymeleaf是适用于Web和独立环境的现代服务器端Java模板引擎。
  2. Thymeleaf的主要目标是为您的开发工作流程带来优雅的自然模板 -HTML可以在浏览器中正确显示,也可以作为静态原型工作,从而可以在开发团队中加强协作。
  3. Thymeleaf拥有适用于Spring Framework的模块,与您喜欢的工具的大量集成以及插入您自己的功能的能力。
    步骤:
    1、pom.xml中引入包:
<dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-thymeleaf</artifactId>
        </dependency>

同时确保spring-boot-starter-web这个包已经引入。

<dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

2、其实默认thymeleaf配置情况下已经可以用了,不过它默认启用了缓存,更适合生产环境,不太适合开发环境,需要关掉。
application.properties文件中,加入配置:

#thymeleaf 缓存设置
spring.thymeleaf.cache=false
spring.thymeleaf.prefix=classpath:/templates/
spring.thymeleaf.encoding=utf-8
spring.thymeleaf.suffix=.html

主要注意的是上面都是默认配置,只有cache=false是修改的。
prefix=classpath:/templates/两边的/都不要漏掉。

3、创建/templates/目录,在resources下。
创建模板文件。
web_1.html 这个包含了一个最简单的text的变量绑定

<!DOCTYPE html>
<html lang="en" xmlns:th="http://www.thymeleaf.org">
<head>
    <meta charset="UTF-8">
<!--  <meta http-equiv="content-type" content="text/html;chatset=UTF-8">-->
    <title>Title</title>
</head>
<body>
<p th:text="${hello}"></p>
</body>
</html>

web_2.html 这个包含了一个List类型变量的绑定,主要是演示遍历循环

<!DOCTYPE html>
<html lang="en" xmlns:th="http://www.thymeleaf.org">
<head>
    <meta charset="UTF-8">
<!--  <meta http-equiv="content-type" content="text/html;chatset=UTF-8">-->
    <title>Title</title>
</head>
<body>
<table border="1" cellspacing="0" cellpadding="0">
    <tr>
        <td>ID</td>
        <td>Fid</td>
        <td>Fname</td>
    </tr>
    <tr th:each="ware:${warehouses}">
        <td th:text="${ware.Id}"></td>
        <td th:text="${ware.Fid}"></td>
        <td th:text="${ware.Fname}"></td>
    </tr>
</table>
</body>
</html>

3、编写控制器文件 Demo2Controller.java

package org.rainpet.controller;

import org.rainpet.entity.Warehouse;
import org.rainpet.service.WarehouseService;
import org.rainpet.utils.StrUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.*;
import org.springframework.web.servlet.ModelAndView;

import javax.servlet.http.HttpServletRequest;
import java.util.LinkedList;
import java.util.List;

@Controller
@RequestMapping("/demo2")
public class Demo2Controller {
    
    @Autowired
    WarehouseService warehouseService;

    @GetMapping("web1")
    public String hello(Model model){
        model.addAttribute("hello","hello welcome");
        return "web_1";
    }

    @GetMapping("web2")
    public String web2(HttpServletRequest request){
        String name="note";
        request.setAttribute("hello",name);
        return "web_1";
    }
    @GetMapping("web3")
    public ModelAndView web3(){
        String name="note3";
        ModelAndView modelAndView=new ModelAndView();
        modelAndView.addObject("name",name);

        List<Warehouse> warehouseList=new LinkedList<>();
        Warehouse warehouse=new Warehouse();
        warehouse.setId(1);
        warehouse.setFid("01");
        warehouse.setFname("测试01");
        warehouseList.add(warehouse);
        modelAndView.addObject("warehouses",warehouseList);
        modelAndView.addObject("warehouse",warehouse);
        modelAndView.setViewName("web_2");
        return modelAndView;
    }
}

需要注意的问题:
① thymeleaf需要配合@Controller 注解使用,一定不能使用@RestController注解
② LinkedList 对象需要java7及以上支持,需要修改项目的java兼容性,我是修改到了java8。
需要修改:Project Structure中项目的SDK、language level;
在这里插入图片描述

各个模块的Language Level、Dependencies中的Model SDK;
在这里插入图片描述
在这里插入图片描述

设置中的Build.Execution,Deployment中Compiler中,java Compiler的各个模块字节码的version,均改为8。在这里插入图片描述

重新编译,同时在父项目中maven中执行install操作方可。
在这里插入图片描述
不然,可能会出现莫名错误:Could not resolve dependencies for project org.rainpet:Web:jar:1.0-SNAPSHOT: Failed to collect dependencies

4、重新编译,运行,打开页面:
http://localhost:8081/demo2/web1
在这里插入图片描述
http://localhost:8081/demo2/web2
在这里插入图片描述
http://localhost:8081/demo2/web3
在这里插入图片描述
到此,项目已经跑起来了。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2062141.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

华普微邀您共聚 2024 elexcon 深圳国际电子展!

elexcon2024深圳国际电子展将于2024年8月27日至29日在深圳会展中心&#xff08;福田&#xff09;开幕。汇聚全球优质品牌厂商齐聚现场&#xff0c;打造电子全产业链创新展示、一站式采购及技术交流平台。集中展示集成电路、嵌入式系统、电源管理/功率器件、电子元件与供应链、O…

气膜馆:亲子乐园中的新兴娱乐空间—轻空间

在亲子乐园中&#xff0c;气膜馆作为一种新兴的娱乐空间&#xff0c;凭借其独特的设计和灵活的功能&#xff0c;成为了孩子和家长们的理想去处。这个轻盈而充满趣味的空间&#xff0c;不仅让孩子们尽情玩耍&#xff0c;也为家长提供了舒适的陪伴环境。 全天候的舒适体验 气膜馆…

AOP+ 自定义注解 +SpringElExpress自研缓存组件

AOP 自定义注解 SpringElExpress自研缓存组件 背景前置知识改造代码 背景 思考下这段代码&#xff0c;想想项目中是不是到处存在 先查缓存&#xff0c;缓存里面有&#xff0c;直接返回&#xff1b;缓存没有&#xff0c;查数据库&#xff0c;并更新到缓存 思考&#xff1a;如何…

你遇到过哪些触发NPE的代码场景?

你遇到过哪些触发NPE的代码场景&#xff1f; NPE如何处理NPE 在Java编程实践中&#xff0c;空指针异常&#xff08;NPE&#xff09;是开发过程中常见的障碍&#xff0c;它不仅阻碍了代码的正常运行&#xff0c;还常常成为系统不稳定性的根源。那么如何识别那些潜藏于代码深处的…

6个你应该尝试Lens.org的理由:一个免费的文献可视化和专利网站

我是娜姐 迪娜学姐 &#xff0c;一个SCI医学期刊编辑&#xff0c;探索用AI工具提效论文写作和发表。 最近发现的一个免费的文献检索工具Lens.org介绍给大家&#xff0c;相比其他文献检索工具web of science、Scopus等&#xff0c;独到之处在于它对于搜索结果全面的可视化呈现效…

ubuntu右上角没有小键盘图标

这个比较奇怪&#xff0c;一开始好好的&#xff0c;用着用着就不行了。网上解决方案比较多&#xff0c;大多数能解决一部分问题。 1.设置“输入法系统” 2.在终端运行 sudo killall ibus-daemon&#xff08;结束进程&#xff09; bus-daemon -d&#xff08;重启ibus&#xff0…

Go之函数

一、函数基本使用 一&#xff09;函数概述 1、函数定义 对特定的功能进行提取&#xff0c;形成一个代码片段 2、函数的作用 提高代码的复用性&#xff0c;减少代码的冗余&#xff0c;代码的维护性也提高了 3、函数中间的关系 函数与函数是并列关系&#xff0c;所以定义的函数不…

Secure Coding in C and C ++ (四)局部静态构造函数 虚函数

前言 上一章节我们讲解了 关于C静态和指针与引用的部分 我们先来回顾一下相关的内容&#xff1a; 指针说白了就是地址&#xff0c; int a; int * ptr &a这里的整形指针 就是存放的整数变量的地址 静态 static 有两种层面&#xff1a; 第一种层面就是在其他的文件里&…

Ansys Zemax|如何自定义优化操作数

虽然Zemax OpticStudio有300多个内建优化操作数&#xff0c;但是还是会有一些特殊情况是这300多个操作数无法涵盖的。这就要求使用者根据要求计算出某些特定的数值&#xff0c;将这些数值返回到某个操作数&#xff0c;再对此操作数进行优化。 Zemax OpticStudio支持用户编程&a…

【SpringCloud】(一文通)多机部署, 负载均衡-LoadBalance

目 录 一. 负载均衡介绍1.2 什么是负载均衡1.3 负载均衡的⼀些实现 二. Spring Cloud LoadBalancer2.1 快速上手2.1.1 使用 Spring Cloud LoadBalancer 实现负载均衡2.1.2 启动多个product-service实例 2.2 负载均衡策略2.3 LoadBalancer 原理 三. 服务部署(Linux)3.2 服务构建…

(24)(24.4) MultiWii/DJI/HDZero OSD (version 4.2 and later)(一)

文章目录 前言 1 基于遥测的OSD 前言 ArduPilot 使用基于MSP&#xff08;MultiWii 串行协议&#xff09;的协议支持多种类型的屏幕显示&#xff08;OSD&#xff09;&#xff1a; 基于 MSP 遥测的操作系统&#xff0c;如大疆 FPV 护目镜 V1/V2、大疆护目镜 RE、FatShark Byte…

QML----QML+VTK+CMake示例

为了创建一个使用QML和VTK的示例项目,并使用CMake进行构建,将遵循以下步骤: 创建C++类以集成VTK和QML:这个类将负责设置VTK渲染数据,并与QML进行交互。设置CMake配置:配置CMake以找到并链接Qt和VTK库。创建QML界面:设计QML界面以显示VTK渲染的内容。编写主函数:初始化应…

C语言实现通讯录-动态版本与文件版本

C语言实现通讯录-动态版本与文件版本 1.前言2.动态版本2.1联系人信息之前的&#xff1a;改版: 2.2初始化之前的&#xff1a;改版&#xff1a; 2.3自动扩容 3.文件版本3.1自动保存函数实现&#xff1a;效果&#xff1a; 3.2打开时加载信息函数实现&#xff1a;效果&#xff1a; …

day37-https实战

1.知识点补充: 四层代理转发数据库 目的: 通过10.0.0.4 使用ssh远程连接到web01 ssh--->10.0.0.4:2222 ---------->172.16.1.7:22 xshell-->创建会话-->10.0.0.4 端口 2222 Linux系统 ssh 10.0.0.4 -p2222作业: 目的: 实现连接10.0.0.4的5555端口转发到后端数据库…

【hot100篇-python刷题记录】【只出现一次的数字】

R5-技巧篇 思路&#xff1a;使用哈希记录次数即可 class Solution:def singleNumber(self, nums: List[int]) -> int:dictdefaultdict(int)for num in nums:dict[num]1for num in nums:if dict[num]1:return num

【hot100篇-python刷题记录】【爬楼梯】

R5-真正的动态规划 动态规划核心&#xff1a; 第i步是怎么来的&#xff08;即动态规划公式&#xff09; 走到第i步阶梯的总方法数sum(走到第i-1步阶梯的总方法数&#xff0c;走到第i-2步阶梯的总方法数) class Solution:def climbStairs(self, n: int) -> int:if n<2:r…

云原生系列 - Nginx(高级篇)

前言 学习视频&#xff1a;尚硅谷Nginx教程&#xff08;亿级流量nginx架构设计&#xff09;本内容仅用于个人学习笔记&#xff0c;如有侵扰&#xff0c;联系删学习文档&#xff1a; 云原生系列 - Nginx(基础篇)云原生系列 - Nginx(高级篇) 一、扩容 通过扩容提升整体吞吐量…

OpenCV resize 的各插值方式的区别与用途

一、resize 函数中 interpolation 参数的区别和用途 cv2.resize 函数中的 interpolation 参数用于指定图像缩放时使用的插值方法。不同的插值方法会影响缩放后图像的质量和处理速度。以下是cv2.INTER_AREA、cv2.INTER_CUBIC、cv2.INTER_NEAREST、cv2.INTER_LINEAR 和 cv2.INTE…

有关应用层面试题有关库的思维导体

面试题目&#xff1a; TCP通信中3次握手和四次挥手&#xff1f; 答&#xff1a; 第一次握手&#xff1a;客户端发送SYN包&#xff08;SYN1, seq0&#xff09;给服务器&#xff0c;并进入SYN_SENT状态&#xff0c;等待服务器返回确认包。第二次握手&#xff1a;服务器接收到S…

什么是Redis大key问题?如何解决?

目录 Key多大算大呢&#xff1f; 识别big key 处理big key Big Key是Redis中存储了大量的数据的Key&#xff0c;不要误以为big key只是表示Key的值很大&#xff0c;他还包括这个Key对应的value占用空间很多的情况&#xff0c;通常在String、list、hash、set、zset等类型中出…