Spring Boot (十五): Spring Boot + Jpa + Thymeleaf 增删改查示例

640这篇文章介绍如何使用 Jpa 和 Thymeleaf 做一个增删改查的示例。

先和大家聊聊我为什么喜欢写这种脚手架的项目,在我学习一门新技术的时候,总是想快速的搭建起一个 Demo 来试试它的效果,越简单越容易上手最好。

在网上找相关资料的时候总是很麻烦,有的文章写的挺不错的但是没有源代码,有的有源代码但是文章介绍又不是很清楚,所在找资料的时候稍微有点费劲。

因此在我学习 Spring Boot 的时候,会写一些最简单基本的示例项目,一方面方便其它朋友以最快的方式去了解,一方面如果我的项目需要用到相关技术的时候,直接在这个示例版本去改造或者集成就可以。

现在的技术博客有很多的流派,有的喜欢分析源码,有的倾向于底层原理,我最喜欢写这种小而美的示例,方便自己方便他人。

其实以前写过 Thymeleaf 和 Jpa 的相关文章: Spring Boot (四): Thymeleaf 使用详解Spring Boot(五):Spring Data Jpa 的使用里面的代码示例都给的云收藏的内容Favorites-web,云收藏的内容比较多,查找起来不是很方便,因此想重新整理一篇快速上手、简单的内容,来介绍 Jpa 和 Thymeleaf 的使用,也就是本文的内容。

这篇文章就不在介绍什么是 Jpa 、 Thymeleaf ,如果还不了解这些基本的概念,可以先移步前两篇相关文章。

快速上手

配置文件

pom 包配置

pom 包里面添加 Jpa 和 Thymeleaf 的相关包引用

<dependency>	
    <groupId>org.springframework.boot</groupId>	
    <artifactId>spring-boot-starter-web</artifactId>	
</dependency>	
<dependency>	
    <groupId>org.springframework.boot</groupId>	
    <artifactId>spring-boot-starter-thymeleaf</artifactId>	
</dependency>	
<dependency>	
    <groupId>org.springframework.boot</groupId>	
    <artifactId>spring-boot-starter-data-jpa</artifactId>	
</dependency>	
<dependency>	
    <groupId>mysql</groupId>	
    <artifactId>mysql-connector-java</artifactId>	
</dependency>

在application.properties中添加配置

spring.datasource.url=jdbc:mysql://127.0.0.1/test?useUnicode=true&characterEncoding=utf-8&serverTimezone=UTC&useSSL=true	
spring.datasource.username=root	
spring.datasource.password=root	
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver	
spring.jpa.properties.hibernate.hbm2ddl.auto=create	
spring.jpa.properties.hibernate.dialect=org.hibernate.dialect.MySQL5InnoDBDialect	
spring.jpa.show-sql= true	
spring.thymeleaf.cache=false

其中 propertiesspring.thymeleaf.cache=false是关闭 Thymeleaf 的缓存,不然在开发过程中修改页面不会立刻生效需要重启,生产可配置为 true。

在项目 resources 目录下会有两个文件夹:static目录用于放置网站的静态内容如 css、js、图片;templates 目录用于放置项目使用的页面模板。

启动类

启动类需要添加 Servlet 的支持

@SpringBootApplication	
public class JpaThymeleafApplication extends SpringBootServletInitializer {	
    @Override	
    protected SpringApplicationBuilder configure(SpringApplicationBuilder application) {	
        return application.sources(JpaThymeleafApplication.class);	
    }	
    public static void main(String[] args) throws Exception {	
        SpringApplication.run(JpaThymeleafApplication.class, args);	
    }	
}

数据库层代码

实体类映射数据库表

@Entity	
public class User {	
    @Id	
    @GeneratedValue	
    private long id;	
    @Column(nullable = false, unique = true)	
    private String userName;	
    @Column(nullable = false)	
    private String password;	
    @Column(nullable = false)	
    private int age;	
    ...	
}

继承 JpaRepository 类会自动实现很多内置的方法,包括增删改查。也可以根据方法名来自动生成相关 Sql,具体可以参考: Spring Boot (五):Spring Data Jpa 的使用

public interface UserRepository extends JpaRepository<User, Long> {	
    User findById(long id);	
    Long deleteById(Long id);	
}

业务层处理

Service 调用 Jpa 实现相关的增删改查,实际项目中 Service 层处理具体的业务代码。

@Service	
public class UserServiceImpl implements UserService{	
    @Autowired	
    private UserRepository userRepository;	
    @Override	
    public List<User> getUserList() {	
        return userRepository.findAll();	
    }	
    @Override	
    public User findUserById(long id) {	
        return userRepository.findById(id);	
    }	
    @Override	
    public void save(User user) {	
        userRepository.save(user);	
    }	
    @Override	
    public void edit(User user) {	
        userRepository.save(user);	
    }	
    @Override	
    public void delete(long id) {	
        userRepository.delete(id);	
    }	
}

Controller 负责接收请求,处理完后将页面内容返回给前端。

@Controller	
public class UserController {	
    @Resource	
    UserService userService;	
    @RequestMapping("/")	
    public String index() {	
        return "redirect:/list";	
    }	
    @RequestMapping("/list")	
    public String list(Model model) {	
        List<User> users=userService.getUserList();	
        model.addAttribute("users", users);	
        return "user/list";	
    }	
    @RequestMapping("/toAdd")	
    public String toAdd() {	
        return "user/userAdd";	
    }	
    @RequestMapping("/add")	
    public String add(User user) {	
        userService.save(user);	
        return "redirect:/list";	
    }	
    @RequestMapping("/toEdit")	
    public String toEdit(Model model,Long id) {	
        User user=userService.findUserById(id);	
        model.addAttribute("user", user);	
        return "user/userEdit";	
    }	
    @RequestMapping("/edit")	
    public String edit(User user) {	
        userService.edit(user);	
        return "redirect:/list";	
    }	
    @RequestMapping("/delete")	
    public String delete(Long id) {	
        userService.delete(id);	
        return "redirect:/list";	
    }	
}
  • return"user/userEdit"; 代表会直接去 resources 目录下找相关的文件。

  • return"redirect:/list"; 代表转发到对应的 Controller,这个示例就相当于删除内容之后自动调整到 list 请求,然后再输出到页面。

页面内容

list 列表

<!DOCTYPE html>	
<html lang="en" xmlns:th="http://www.thymeleaf.org">	
<head>	
    <meta charset="UTF-8"/>	
    <title>userList</title>	
    <link rel="stylesheet" th:href="@{/css/bootstrap.css}"></link>	
</head>	
<body class="container">	
<br/>	
<h1>用户列表</h1>	
<br/><br/>	
<div class="with:80%">	
    <table class="table table-hover">	
        <thead>	
        <tr>	
            <th>#</th>	
            <th>User Name</th>	
            <th>Password</th>	
            <th>Age</th>	
            <th>Edit</th>	
            <th>Delete</th>	
        </tr>	
        </thead>	
        <tbody>	
        <tr  th:each="user : ${users}">	
            <th scope="row" th:text="${user.id}">1</th>	
            <td th:text="${user.userName}">neo</td>	
            <td th:text="${user.password}">Otto</td>	
            <td th:text="${user.age}">6</td>	
            <td><a th:href="@{/toEdit(id=${user.id})}">edit</a></td>	
            <td><a th:href="@{/delete(id=${user.id})}">delete</a></td>	
        </tr>	
        </tbody>	
    </table>	
</div>	
<div class="form-group">	
    <div class="col-sm-2 control-label">	
        <a href="/toAdd" th:href="@{/toAdd}" class="btn btn-info">add</a>	
    </div>	
</div>	
</body>	
</html>

效果图:

640<trth:each="user : ${users}"> 这里会从 Controler 层 model set 的对象去获取相关的内容, th:each表示会循环遍历对象内容。

其实还有其它的写法,具体的语法内容可以参考这篇文章: Spring Boot (四): Thymeleaf 使用详解

修改页面:

&lt;!DOCTYPE html&gt;	
&lt;html lang="en" xmlns:th="http://www.thymeleaf.org"&gt;	
&lt;head&gt;	
    &lt;meta charset="UTF-8"/&gt;	
    &lt;title&gt;user&lt;/title&gt;	
    &lt;link rel="stylesheet" th:href="@{/css/bootstrap.css}"&gt;&lt;/link&gt;	
&lt;/head&gt;	
&lt;body class="container"&gt;	
&lt;br/&gt;	
&lt;h1&gt;修改用户&lt;/h1&gt;	
&lt;br/&gt;&lt;br/&gt;	
&lt;div class="with:80%"&gt;	
    &lt;form class="form-horizontal"   th:action="@{/edit}" th:object="${user}"  method="post"&gt;	
        &lt;input type="hidden" name="id" th:value="*{id}" /&gt;	
        &lt;div class="form-group"&gt;	
            &lt;label for="userName" class="col-sm-2 control-label"&gt;userName&lt;/label&gt;	
            &lt;div class="col-sm-10"&gt;	
                &lt;input type="text" class="form-control" name="userName"  id="userName" th:value="*{userName}" placeholder="userName"/&gt;	
            &lt;/div&gt;	
        &lt;/div&gt;	
        &lt;div class="form-group"&gt;	
            &lt;label for="password" class="col-sm-2 control-label" &gt;Password&lt;/label&gt;	
            &lt;div class="col-sm-10"&gt;	
                &lt;input type="password" class="form-control" name="password" id="password"  th:value="*{password}" placeholder="Password"/&gt;	
            &lt;/div&gt;	
        &lt;/div&gt;	
        &lt;div class="form-group"&gt;	
            &lt;label for="age" class="col-sm-2 control-label"&gt;age&lt;/label&gt;	
            &lt;div class="col-sm-10"&gt;	
                &lt;input type="text" class="form-control" name="age"  id="age" th:value="*{age}" placeholder="age"/&gt;	
            &lt;/div&gt;	
        &lt;/div&gt;	
        &lt;div class="form-group"&gt;	
            &lt;div class="col-sm-offset-2 col-sm-10"&gt;	
                &lt;input type="submit" value="Submit" class="btn btn-info" /&gt;	
                &amp;nbsp; &amp;nbsp; &amp;nbsp;	
                &lt;a href="/toAdd" th:href="@{/list}" class="btn btn-info"&gt;Back&lt;/a&gt;	
            &lt;/div&gt;	
        &lt;/div&gt;	
    &lt;/form&gt;	
&lt;/div&gt;	
&lt;/body&gt;	
&lt;/html&gt;

添加页面和修改类似就不在贴代码了。

效果图:

640?wx_fmt=png

这样一个使用 Jpa 和 Thymeleaf 的增删改查示例就完成了。

文章内容已经升级到 Spring Boot 2.x

示例代码-https://github.com/ityouknow/spring-boot-examples

-END-


作者介绍纯洁的微笑一枚超过十年的一线老兵,目前在技术自媒体行业折腾。

Java 极客技术公众号是由一群热爱 Java 开发的技术人组建成立,专注分享原创高质量Java 文章。如果您觉得我们的文章还不错,请帮忙赞赏、在看、转发支持,鼓励我们分享出更好的文章。


640?wx_fmt=jpeg

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值