spring boot:实现jpa+thymeleaf 用户管理

Posted 加辣椒了吗?

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了spring boot:实现jpa+thymeleaf 用户管理相关的知识,希望对你有一定的参考价值。

文章目录


今天布置的spring boot小作业:

实现controller 和 模板
/users 查看用户列表
/users/del 删除 用户
/users/add 新增用户
/users/edit 修改用户


一、实现原理

前端采用semantic ui框架,ajax实现数据发送,
后端采用ssm三层架构,实现jpa+thymeleaf 用户管理

二、代码

1.基本类(po/dao层)

user.java:

package com.example.po;

import lombok.Data;

import javax.persistence.*;

/**
 * @ClassName user
 * @Description TODO
 * @Author 加辣椒了吗?
 * @Date 2021/9/21 20:42
 * @Version 1.0
 **/
@Data
@Entity
@Table(name = "t_user")
public class user 
    @Id
    @GeneratedValue
    private Integer id;
    private String name;
    private String email;


2.服务层

继承顺序jpa接口:
jparespository.java:

package com.example.respository;

import com.example.po.user;
import org.springframework.data.jpa.repository.JpaRepository;

/**
 * @ClassName jparespository
 * @Description TODO
 * @Author 加辣椒了吗?
 * @Date 2021/9/21 20:41
 * @Version 1.0
 **/
public interface jparespository extends JpaRepository<user,Integer> 
    public user save(user user);
    public void deleteById(Integer id);


3.控制层

package com.example.controller;

import com.example.po.user;
import com.example.respository.jparespository;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.*;

import java.util.List;
import java.util.Optional;

/**
 * @ClassName usercontroller
 * @Description TODO
 * @Date 2021/9/21 21:00
 * @Version 1.0
 **/
@Controller
public class usercontroller 

    @Autowired
    private jparespository jparespository;
    // 查看全部
    @GetMapping("/users")
    public String findAll(Model model) 
        List<user> all = jparespository.findAll();
        System.out.println(all);
        model.addAttribute("userlist",all);
        return "user";
    
    // 修改用户
    @PostMapping("/users/edit")
    public String edit(@RequestBody user user , Model model) 
        jparespository.save(user);
        List<user> all = jparespository.findAll();
        model.addAttribute("userlist",all);
        return "user";
    
    // 添加用户

    @PostMapping("/users/add")
    public String add(@RequestBody user user , Model model) 
        System.out.println(user);
        jparespository.save(user);
        List<user> all = jparespository.findAll();
        model.addAttribute("userlist",all);
        return "user";
    
    // 删除用户
    @PostMapping("/users/del")
    public String delete(@RequestBody user user, Model model) 
        System.out.println("11111");
        jparespository.deleteById(user.getId());
        List<user> all = jparespository.findAll();
        model.addAttribute("userlist",all);
        return "user";
    

4.thymeleaf 前端代码

<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org">
<head>
  <title>Getting Started: Serving Web Content</title>
  <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
  <link rel="stylesheet" type="text/css" href="../css/semantic.min.css">
</head>
<body>

</br>
<div style="text-align: center">
  <button class="ui button" id="adduser">add</button>
  <button class="ui button" id="edituser">edit</button>
  <button class="ui button" id="deleteuser">delete</button>
</div>
</br>
<div style="padding-left: 400px">
  <table class="ui celled table" style="width: 500px;">
    <thead>
    <tr>
      <th>id</th>
      <th>name</th>
      <th>email</th>
    </tr>
    </thead>
    <tbody>
    <tr th:each="user:$userlist">
      <td data-label="id" th:text="$user.id"></td>
      <td data-label="name" th:text="$user.name"></td>
      <td data-label="email" th:text="$user.email"></td>
    </tr>
    </tbody>
  </table>
</div>

<div class="ui modal add">
  <div class="header">添加用户</div>
  <div class="content">
    <form class="ui form addform">
      <div class="field">
        <label>name</label>
        <input class="name" name="name" type="text">
        <label>email</label>
        <input class="email" name="email" type="text">
      </div>
      <div class="ui submit button">Submit</div>
      <div class="ui error message"></div>
    </form>
  </div>
</div>

<div class="ui modal edit">
  <div class="header">修改用户</div>
  <div class="content">
    <form class="ui form editform">
      <div class="field">
        <label>id</label>
        <input class="id2" name="id2" type="text">
        <label>name</label>
        <input class="name2" name="name2" type="text">
        <label>email</label>
        <input class="email2" name="email2" type="text">
      </div>
      <div class="ui submit button">Submit</div>
      <div class="ui error message"></div>
    </form>
  </div>
</div>

<div class="ui modal delete">
  <div class="header">请输入你要删除的用户id</div>
  <div class="content">
    <form class="ui form deleteform">
      <div class="field">
        <label>id</label>
        <input class="id3" name="id3" type="text">
      </div>
      <div class="ui submit button">Submit</div>
      <div class="ui error message"></div>
    </form>
  </div>
</div>

<script src="../js/jquery-1.11.3.min.js"> </script>
<script src="../js/semantic.min.js"></script>
<script>
  $(document).ready(function()
    var data = 
      id:0,
      name:"ct",
      email:"qq"
    
    // 添加事件
    $("#adduser").on("click",function()
      $('.add').modal('show');
    );
    // 编辑事件
    $("#edituser").on("click",function()
      $('.edit').modal('show');
    );
    // 删除事件
    $("#deleteuser").on("click",function()
      $('.delete').modal('show');
    );
    // 验证规则
    $(function () 
      $(".ui.form").form(
        fields:
          name:
            indentfier:'name',
            rules:[
              type   : 'empty',
              prompt : 'Please enter the value of name'
            ]
          ,
          email:
            indentfier:'email',
            rules:[
              type   : 'empty',
              prompt : 'Please enter the value of email'
            ]
          ,
          id2:
            indentfier:'id2',
            rules:[
              type   : 'empty',
              prompt : 'Please enter the value of id'
            ]
          ,
          name2:
            indentfier:'name2',
            rules:[
              type   : 'empty',
              prompt : 'Please enter the value of name'
            ]
          ,
          email2:
            indentfier:'email2',
            rules:[
              type   : 'empty',
              prompt : 'Please enter the value of email'
            ]
          ,
          id3:
            indentfier:'id3',
            rules:[
              type   : 'empty',
              prompt : 'Please enter the value of id'
            ]
          ,
        
      )
    )
    // 添加提交事件
    $(".addform").submit(function()
      // console.log($(".id").val())
      // console.log($(".name").val())
      // console.log($(".email").val())

      data.name = $(".name").val()
      data.email = $(".email").val()
      console.log(data)
      $.ajax(
        url: "/users/add",
        type: "POST",
        dataType:'json',
        contentType:'application/json;charset=UTF-8',
        data:JSON.stringify(data)
      );
      alert("添加成功!");
    );
    // 修改提交事件
    $(".editform").submit(function()
      // console.log($(".id2").val())
      // console.log($(".name2").val())
      // console.log($(".email2").val())
      data.id = $(".id2").val()
      data.name = $(".name2").val()
      data.email = $(".email2").val()
      console.log(data)
      $.ajax(
        url: "/users/edit",
        type: "POST",
        dataType:'json',
        contentType:'application/json;charset=UTF-8',
        data:JSON.stringify(data)
      );
      alert("修改成功!");
    );
    // 删除提交事件
    $(".deleteform").submit(function()
      data.id = $(".id3").val()
      $.ajax(
        url: "/users/del",
        type: "POST",
        dataType:'json',
        contentType:'application/json;charset=UTF-8',
        data:JSON.stringify(data)
      );
      alert("删除成功!");
    );
  );


</script>
</body>
</html>

5.演示效果




总结

@作者:加辣椒了吗?
简介:憨批大学生一枚,喜欢在博客上记录自己的学习心得,也希望能够帮助到你们!

以上是关于spring boot:实现jpa+thymeleaf 用户管理的主要内容,如果未能解决你的问题,请参考以下文章

Spring Boot中使用Spring Data JPA示例

spring boot 系列之四:spring boot 整合JPA

在Spring Boot中使用Spring-data-jpa实现分页查询(转)

spring boot2 整合JPA(特别完整!)

spring boot:实现jpa+thymeleaf 用户管理

spring boot:实现jpa+thymeleaf 用户管理