Spring 全家桶之 Spring Boot 2.6.4(六)- Web Develop(Part C)(下)

简介: Spring 全家桶之 Spring Boot 2.6.4(六)- Web Develop(Part C)(下)

重新启动应用,点击Add按钮

490b0cab1870428ca9ec6c8d8248235f_tplv-k3u1fbpfcp-zoom-in-crop-mark_4536_0_0_0.png

能正常跳转至页面

修改添加表单为如下:

<form>
   <div class="form-group">
      <label>LastName</label>
      <input type="text" class="form-control" placeholder="loki">
   </div>
   <div class="form-group">
      <label>Email</label>
      <input type="email" class="form-control" placeholder="loki@asgard.com">
   </div>
   <div class="form-group">
      <label>Gender</label><br/>
      <div class="form-check form-check-inline">
         <input class="form-check-input" type="radio" name="gender"  value="1">
         <label class="form-check-label">男</label>
      </div>
      <div class="form-check form-check-inline">
         <input class="form-check-input" type="radio" name="gender"  value="0">
         <label class="form-check-label">女</label>
      </div>
   </div>
   <div class="form-group">
      <label>Department</label>
      <select class="form-control">
         <option>1</option>
         <option>2</option>
         <option>3</option>
         <option>4</option>
         <option>5</option>
      </select>
   </div>
   <button type="submit" class="btn btn-primary">添加</button>
</form>
复制代码

修改employee方法,在跳转至add.html页面前需要将部门信息查出来在下拉框中展示

@GetMapping("/employee")
public String employee(Model model){
    Collection<Department> departments = departmentMapper.getDepartments();
    model.addAttribute("departments", departments);
    return "employee/add";
}
复制代码

在页面下拉框中取出部门信息

531a8e8abc64400695dd9d097df369f7_tplv-k3u1fbpfcp-zoom-in-crop-mark_4536_0_0_0.png

重启应用

b6be0f59379540dfac5b1a6ebc24a909_tplv-k3u1fbpfcp-zoom-in-crop-mark_4536_0_0_0.png

执行 Add Employee

修改form表单提交地址为th:action="@{/add}",提交方式post,并对每个input标签增加name属性

在EmployeeController中的add()方法中调用employeeMapper的save()方法,保存新增加的Employee对象

@PostMapping("/add")
public String add(Employee employee){
    System.out.println(employee);
    employeeMapper.save(employee);
    return "redirect:/list";
}
复制代码

重启应用,进入添加页面

e40e1e723e6942d88f0bc396aa4b523f_tplv-k3u1fbpfcp-zoom-in-crop-mark_4536_0_0_0.png

点击添加按钮,员工添加成功

b8f13dbca49f4ae2b003e1644cdab4c5_tplv-k3u1fbpfcp-zoom-in-crop-mark_4536_0_0_0.png

控制台打印出提交的员工信息

2625d563bc3040b09a3a5bb73e903898_tplv-k3u1fbpfcp-zoom-in-crop-mark_4536_0_0_0.png

六、Edit Employee

来到信息修改页面

点编辑按钮来到添加表单,添加和修改都是用add.html,同时回显要修改的员工信息,对编辑按钮增加超链接

<a class="btn btn-sm btn-primary" th:href="@{/edit/}+${emp.id}">EDIT</a>
复制代码

在add.html的input标签中使用th:value="${emp.latName}"来回显数据,对于单选按钮回显数据使用th:checked="${emp.gender==1}",表达式为True就选中,否则就不会选中

d1768d41716e4ecb9135b62e0360b031_tplv-k3u1fbpfcp-zoom-in-crop-mark_4536_0_0_0.png

选中部门使用th:selected

66c50a9425a44d78a6ff2f7358c6fef5_tplv-k3u1fbpfcp-zoom-in-crop-mark_4536_0_0_0.png

如果循环到的部门的id与当前员工的部门id一致就显示该部门的name

重启应用,点击EDIT按钮

1985a69adbd84825852d4c09f5528fb2_tplv-k3u1fbpfcp-zoom-in-crop-mark_4536_0_0_0.png

可以正常回显数据

但是在list.html页面点击添加按钮,服务端后台报错

d8f5110cfa574090ac0a96355e78a00e_tplv-k3u1fbpfcp-zoom-in-crop-mark_4536_0_0_0.png

这是应为点击添加来到页面时,并没有传递employee对象,空对象获取lastName属性值,所以会报错,因此需要区分是员工修改还是员工添加,只有在employee对象不为空的时候才是编辑页面,才会进行数据回显

f41be1934ac1440096f5c7ead13d712a_tplv-k3u1fbpfcp-zoom-in-crop-mark_4536_0_0_0.png

重新启动,点击添加按钮

a26f4b714b3049e58e21191a007f74b6_tplv-k3u1fbpfcp-zoom-in-crop-mark_4536_0_0_0.png

页面能正常显示。

执行修改操作

对员工信息修改需要发送PUT请求,需要在表单上对请求方式进行修改

<input type="hidden" name="_method" value="put" th:if="${emp!=null}">
复制代码

配置文件增加配置

spring.mvc.hiddenmethod.filter.enabled=true
复制代码

EmployeeController中增加方法

@PutMapping("/add")
public String edit(Employee employee){
    System.out.println(employee);
    employeeMapper.save(employee);
    return "redirect:/list";
}
复制代码

重启应用,进入编辑界面,编辑并提交数据

8c5df0e993524d28a95bfe9a5d75f085_tplv-k3u1fbpfcp-zoom-in-crop-mark_4536_0_0_0.png

此时控制台打印出的employee对象中的id为空,因此需要在form添加中添加一个隐藏的input框,将id传递到服务端,如下图所示

94b24c473f864e9083cc9fb4a8612c41_tplv-k3u1fbpfcp-zoom-in-crop-mark_4536_0_0_0.png

重新启动应用,再次测试

92c81094ed63486aa2f2e191565da020_tplv-k3u1fbpfcp-zoom-in-crop-mark_4536_0_0_0.png

修改成功

七、Delete Employee

在EmployeeController中增加删除方法方法

@DeleteMapping("/delete/{id}")
public String delete(@PathVariable("id") Integer id){
    employeeMapper.delete(id);
    return "redirect:/list";
}
复制代码

list.html页面需要通过js来提交Delete方式的请求,删除按钮修改为如下

<td>
   <a class="btn btn-sm btn-primary" th:href="@{/edit/}+${emp.id}">EDIT</a>
   <button th:attr="del_uri=@{/delete/}+${emp.id}" class="btn btn-sm btn-danger deleteBtn">DELETE</button>
</td>
复制代码

在main标签同级下增加提交的表单

<form id="deleteEmpForm"  method="post">
   <input type="hidden" name="_method" value="delete"/>
</form>
复制代码

增加js脚本,提价表单

<script>
   $(".deleteBtn").click(function(){
      //删除当前员工的
      $("#deleteEmpForm").attr("action",$(this).attr("del_uri")).submit();
      return false;
   });
</script>
复制代码

重新启动页面,点击删除按钮

51661c25804d4531ac85ec2637a29318_tplv-k3u1fbpfcp-zoom-in-crop-mark_4536_0_0_0.png

成功删除


相关文章
|
4天前
|
XML Java 应用服务中间件
Spring Boot 两种部署到服务器的方式
本文介绍了Spring Boot项目的两种部署方式:jar包和war包。Jar包方式使用内置Tomcat,只需配置JDK 1.8及以上环境,通过`nohup java -jar`命令后台运行,并开放服务器端口即可访问。War包则需将项目打包后放入外部Tomcat的webapps目录,修改启动类继承`SpringBootServletInitializer`并调整pom.xml中的打包类型为war,最后启动Tomcat访问应用。两者各有优劣,jar包更简单便捷,而war包适合传统部署场景。需要注意的是,war包部署时,内置Tomcat的端口配置不会生效。
89 17
Spring Boot 两种部署到服务器的方式
|
3月前
|
Java API 数据库
构建RESTful API已经成为现代Web开发的标准做法之一。Spring Boot框架因其简洁的配置、快速的启动特性及丰富的功能集而备受开发者青睐。
【10月更文挑战第11天】本文介绍如何使用Spring Boot构建在线图书管理系统的RESTful API。通过创建Spring Boot项目,定义`Book`实体类、`BookRepository`接口和`BookService`服务类,最后实现`BookController`控制器来处理HTTP请求,展示了从基础环境搭建到API测试的完整过程。
68 4
|
11天前
|
缓存 安全 Java
Spring Boot 3 集成 Spring Security + JWT
本文详细介绍了如何使用Spring Boot 3和Spring Security集成JWT,实现前后端分离的安全认证概述了从入门到引入数据库,再到使用JWT的完整流程。列举了项目中用到的关键依赖,如MyBatis-Plus、Hutool等。简要提及了系统配置表、部门表、字典表等表结构。使用Hutool-jwt工具类进行JWT校验。配置忽略路径、禁用CSRF、添加JWT校验过滤器等。实现登录接口,返回token等信息。
173 12
|
17天前
|
存储 安全 Java
Spring Boot 3 集成Spring AOP实现系统日志记录
本文介绍了如何在Spring Boot 3中集成Spring AOP实现系统日志记录功能。通过定义`SysLog`注解和配置相应的AOP切面,可以在方法执行前后自动记录日志信息,包括操作的开始时间、结束时间、请求参数、返回结果、异常信息等,并将这些信息保存到数据库中。此外,还使用了`ThreadLocal`变量来存储每个线程独立的日志数据,确保线程安全。文中还展示了项目实战中的部分代码片段,以及基于Spring Boot 3 + Vue 3构建的快速开发框架的简介与内置功能列表。此框架结合了当前主流技术栈,提供了用户管理、权限控制、接口文档自动生成等多项实用特性。
69 8
|
29天前
|
缓存 前端开发 Java
【Spring】——SpringBoot项目创建
SpringBoot项目创建,SpringBootApplication启动类,target文件,web服务器,tomcat,访问服务器
|
1月前
|
Java 开发者 微服务
Spring Boot 入门:简化 Java Web 开发的强大工具
Spring Boot 是一个开源的 Java 基础框架,用于创建独立、生产级别的基于Spring框架的应用程序。它旨在简化Spring应用的初始搭建以及开发过程。
85 6
Spring Boot 入门:简化 Java Web 开发的强大工具
|
2月前
|
监控 Java 数据库连接
详解Spring Batch:在Spring Boot中实现高效批处理
详解Spring Batch:在Spring Boot中实现高效批处理
374 12
|
2月前
|
安全 Java 测试技术
详解Spring Profiles:在Spring Boot中实现环境配置管理
详解Spring Profiles:在Spring Boot中实现环境配置管理
128 10
|
1月前
|
负载均衡 Java 开发者
深入探索Spring Cloud与Spring Boot:构建微服务架构的实践经验
深入探索Spring Cloud与Spring Boot:构建微服务架构的实践经验
178 5
|
2月前
|
存储 运维 安全
Spring运维之boot项目多环境(yaml 多文件 proerties)及分组管理与开发控制
通过以上措施,可以保证Spring Boot项目的配置管理在专业水准上,并且易于维护和管理,符合搜索引擎收录标准。
66 2