这一次我们讲解的主题为SpringBoot整合Thymeleaf的增删查改的案例,首先简单介绍一下Thymeleaf,Thymeleaf是用于Web和独立环境的现代服务器端Java模板引擎,主要应用与前端界面的设计。官网为https://www.thymeleaf.org,里面有该模板引擎的相关解释和用法,不清楚的可以自己到官网上查阅相关的资料。
下面开始进入这次分享的案例,首先展示一下项目树的截图,如下所示:
我们新建一个SpringBoot的项目,命名为usermanage,选择数据库为mysql,首先我们在pom.xml文件中添加相关的配置,完整代码如下:
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.1.3.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.autuleaf</groupId>
<artifactId>usermanage</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>usermanage</name>
<description>Demo project for Spring Boot</description>
<properties>
<java.version>1.8</java.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-thymeleaf</artifactId>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-lang3</artifactId>
<version>3.8.1</version>
</dependency>
<!--实现热部署-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<optional>true</optional>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<fork>
</fork>
</configuration>
</plugin>
</plugins>
</build>
</project>
然后我们在application.properties中添加相关数据库的配置信息,代码如下:
#设置为东八区
spring.datasource.url = jdbc:mysql://localhost:3306/db_userinfo?serverTimezone=GMT%2B8&characterEncoding=utf8
spring.datasource.username= root
spring.datasource.password= 123456
spring.datasource.driver-class-name= com.mysql.cj.jdbc.Driver
#指定连接池中最大的活跃数
spring.datasource.tomcat.max-active= 20
#指定连接池最大的空闲连接
spring.datasource.tomcat.max-idle= 8
#指定必须保持连接的最小值
spring.datasource.tomcat.min-idle= 8
#指定启动连接池时,初始的连接数量
spring.datasource.tomcat.initial-size= 10
#JPA持久化设置
spring.jpa.database= mysql
#指定是否需要在日志中显示SQL语句
spring.jpa.show-sql= true
#不启用视图
spring.jpa.open-in-view=false
#指定自动创建|更新|验证数据库表结构
spring.jpa.hibernate.ddl-auto= update
#不开启缓存
spring.thymeleaf.cache=false
#表中字段命名策略,这里要引入hibernate的核心包,不然这个命名策略会报错
spring.jpa.hibernate.naming.implicit-strategy=org.hibernate.boot.model.naming.ImplicitNamingStrategyLegacyJpaImpl
spring.jpa.hibernate.naming.physical-strategy=org.hibernate.boot.model.naming.PhysicalNamingStrategyStandardImpl
#指定数据库方言
spring.jpa.properties.hibernate.dialect = org.hibernate.dialect.MySQL5Dialect
这里我们在resources下引入bootstrap.css和jquery.js文件,接下来我们先新建实体类UserInfo,代码如下:
package com.autuleaf.us