springboot(十五):springboot+jpa+thymeleaf增刪改查示例

ityouknow發表於2017-09-26

這篇文章介紹如何使用jpa和thymeleaf做一個增刪改查的示例。

先和大家聊聊我為什麼喜歡寫這種腳手架的專案,在我學習一門新技術的時候,總是想快速的搭建起一個demo來試試它的效果,越簡單越容易上手最好。在網上找相關資料的時候總是很麻煩,有的文章寫的挺不錯的但是沒有原始碼,有的有原始碼但是文章介紹又不是很清楚,所在找資料的時候稍微有點費勁。因此在我學習Spring Boot的時候,會寫一些最簡單基本的示例專案,一方面方便其它朋友以最快的方式去了解,一方面如果我的專案需要用到相關技術的時候,直接在這個示例版本去改造或者整合就可以。

現在的技術部落格有很多的流派,有的喜歡分析原始碼,有的傾向於底層原理,我最喜歡寫這種小而美的示例,方便自己方便他人。

其實以前寫過thymeleaf和jpa的相關文章:springboot(四):thymeleaf使用詳解-thymeleaf%E4%BD%BF%E7%94%A8%E8%AF%A6%E8%A7%A3.html)和springboot(五):spring data jpa的使用-spring-data-jpa%E7%9A%84%E4%BD%BF%E7%94%A8.html) 裡面的程式碼示例都給的雲收藏的內容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.jdbc.Driver

spring.jpa.properties.hibernate.hbm2ddl.auto=update
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,具體可以參考:springboot(五):spring data jpa的使用-spring-data-jpa%E7%9A%84%E4%BD%BF%E7%94%A8.html)

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>複製程式碼

效果圖:

<tr th:each="user : ${users}"> 這裡會從controler層model set的物件去獲取相關的內容,th:each表示會迴圈遍歷物件內容。

其實還有其它的寫法,具體的語法內容可以參考這篇文章:springboot(四):thymeleaf使用詳解-thymeleaf%E4%BD%BF%E7%94%A8%E8%AF%A6%E8%A7%A3.html)

修改頁面:

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

        </div>
    </form>
</div>
</body>
</html>複製程式碼

新增頁面和修改類似就不在貼程式碼了。

效果圖:

這樣一個使用jpa和thymeleaf的增刪改查示例就完成了。

當然所以的示例程式碼都在這裡:
示例程式碼


喜歡我的文章,請關注我的公眾號

相關文章