SpringMVC第七阶段:SpringMVC的增删改查(02)

news2025/1/12 7:00:31

1、图书列表功能的实现

需要导入JSTL标签库的jar包:

druid-1.1.9.jar
junit_4.12.jar
mysql-connector-java-5.1.37-bin.jar
org.hamcrest.core_1.3.0.jar
spring-aop-5.2.5.RELEASE.jar
spring-beans-5.2.5.RELEASE.jar
spring-context-5.2.5.RELEASE.jar
spring-core-5.2.5.RELEASE.jar
spring-expression-5.2.5.RELEASE.jar
spring-jcl-5.2.5.RELEASE.jar
spring-jdbc-5.2.5.RELEASE.jar
spring-orm-5.2.5.RELEASE.jar
spring-test-5.2.5.RELEASE.jar
spring-tx-5.2.5.RELEASE.jar
spring-web-5.2.5.RELEASE.jar
spring-webmvc-5.2.5.RELEASE.jar
taglibs-standard-impl-1.2.1.jar
taglibs-standard-spec-1.2.1.jar

BookController控制器:

@RequestMapping("/book")
@Controller
public class BookController {

    @Autowired
    BookService bookService;

    @RequestMapping(value = "/list")
    public String list(Map map){
        // 查询全部图书
        List<Book> books = bookService.queryBooks();
        // 保存到Request域中
        map.put("books", books);
        // 请求转发到/book/bookList.jsp页面
        return "bookList";
    }

}

bookList.jsp页面的代码:

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
   <head>
      <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
      <title>图书列表</title>
      <%
         String basePath = request.getScheme() 
                        + "://"
                        + request.getServerName()
                        + ":"
                        + request.getServerPort()
                        + request.getContextPath()
                        + "/";
      %>
      <base href="<%=basePath %>" />
      <style type="text/css">
         table {
            border: 1px blue solid;
            width: 700px;
            border-collapse: collapse;
         }
         td,th{
            border: 1px green solid;
         }
         div.menu {
            width: 700px;
            text-align: right;
         }
      </style>
   </head>
   <body>
      <center>
         <h2>图书列表管理页面</h2>
         <div class="menu"><a href="${pageContext.request.contextPath}/book/bookEdit.jsp">添加图书</a></div>
         <table>
            <tr bgcolor="#FF8888">
               <th>书名</th>
               <th>作者</th>
               <th>价格</th>
               <th>销量</th>
               <th>库存</th>
               <th>操作</th>
            </tr>
            <%--
               forEach 遍历list集合
                  items 是当前遍历的数据源
                  var 是当前遍历到的数据
            --%>
            <c:forEach items="${requestScope.books}" var="book">
               <tr>
                  <td>${book.name}</td>
                  <td>${book.author}</td>
                  <td>${book.price}</td>
                  <td>${book.sales}</td>
                  <td>${book.stock}</td>
                  <td><a href="#">删除</a><a href="#">修改</a></td>
               </tr>
            </c:forEach>
         </table>
      </center>
   </body>
</html>

2、图书添加功能的实现

bookEdit.jsp页面修改

在这里插入图片描述

BookController代码:

@RequestMapping(value = "/save")
public String save(Book book){
    // 保存图书信息
    bookService.saveBook(book);
    // 重定向回图书列表管理页面
    return "redirect:/book/list";
}

解决post请求中文乱码,只需要在web.xml中做以下配置即可:

<!--
    配置过滤器解决post请求中文乱码
-->
<filter>
    <filter-name>CharacterEncodingFilter</filter-name>
    <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
    <init-param>
        <param-name>encoding</param-name>
        <param-value>UTF-8</param-value>
    </init-param>
    <init-param>
        <param-name>forceRequestEncoding</param-name>
        <param-value>true</param-value>
    </init-param>
    <init-param>
        <param-name>forceResponseEncoding</param-name>
        <param-value>true</param-value>
    </init-param>
</filter>
<filter-mapping>
    <filter-name>CharacterEncodingFilter</filter-name>
    <url-pattern>/*</url-pattern>
</filter-mapping>

3、图书删除功能的实现

给删除添加请求地址:
在这里插入图片描述

BookController中的代码:

@RequestMapping(value = "/delete")
public String delete(Integer id){
    // 调用bookService.deleteBookById()删除图书
    bookService.deleteBookById(id);
    // 重定向回图书列表管理页面
    return "redirect:/book/list";
}

SpringMVC默认情况下.是不支持处理静态资源的.
为什么默认不支持静态资源.

由于我们在WEB.xml 配置文件中 给前端控制器配置的请求路径是 : /
这个路径 和 Tomcat 服务器 提供的一个静态资源处理的DefaultServlet程序相冲突.
导致 Tomcat 服务器 失去了对静态资源处理的能力.

如何解决SpringMVC处理静态 资源问题:

<!--
    使用SpringMVC开发项目.必须加上以下两个配置
    SpringMVC标配
    允许SpringMVC支持静态资源的处理( 重启才能生效 )
-->
<mvc:default-servlet-handler />
<!--
    配置处理SpringMVC高级功能
-->
<mvc:annotation-driven></mvc:annotation-driven>

给删除的a标签添加一个删除样式:
在这里插入图片描述

给删除的a标签绑定单击事件:

$(function () {
   // alert("页面加载完成之后!!!");
   // 给删除的a标签绑定单击事件
   $("a.deleteAClass").click(function () {
      // 通过删除的a标签,获取两次父元素.得到tr标签对象
      let name = $(this).parent().parent().find("td:first").text();
      return confirm(" 你确定要删除[ " + name + " ]吗? ");
      // // 阻止元素默认行为
      // return false;
   });
});

4、图书更新功能的实现

第一步:点击 [修改] 超连接,把需要更新的图书信息,填充到bookEdit.jsp页面
给 [ 修改 ] 连接添加请求地址:
在这里插入图片描述

BookController控制 中的方法:

@RequestMapping(value = "/queryBookById")
public String queryBookById(Integer id,Map<String,Object> map){
    // 调用bookService.queryBookById查询图书, 并且保存到Request域中
    map.put("book",bookService.queryBookById(id));
    // 请求转发到 /book/bookEdit.jsp页面
    return "bookEdit";
}

bookEdit.jsp页面回显数据:

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
   <head>
      <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
      <title>图书列表</title>
      <%
         String basePath = request.getScheme() 
                        + "://"
                        + request.getServerName()
                        + ":"
                        + request.getServerPort()
                        + request.getContextPath()
                        + "/";
      %>
      <base href="<%=basePath %>" />
   </head>
   <body>
      <center>
         <h3>添加图书</h3>
         <%--
            使用GET请求没有中文乱码
         --%>
         <form action="${pageContext.request.contextPath}/book/save">
            <table>
               <tr>
                  <td>书名</td>
                  <td><input name="name" type="text"
                           value="${requestScope.book.name}"/></td>
               </tr>
               <tr>
                  <td>作者</td>
                  <td><input name="author" type="text"
                     value="${requestScope.book.author}"/></td>
               </tr>
               <tr>
                  <td>价格</td>
                  <td><input name="price" type="text"
                     value="${requestScope.book.price}"/></td>
               </tr>
               <tr>
                  <td>销量</td>
                  <td><input name="sales" type="text"
                     value="${requestScope.book.sales}"/></td>
               </tr>
               <tr>
                  <td>库存</td>
                  <td><input name="stock" type="text"
                     value="${requestScope.book.stock}"/></td>
               </tr>
               <tr>
                  <td align="center" colspan="2">
                     <input type="submit" />
                  </td>
               </tr>
            </table>
         </form>
      </center>
   </body>
</html>

第二步:提交数据给服务器确认修改

bookEdit.jsp页面的内容:

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
   <head>
      <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
      <title>图书列表</title>
      <%
         String basePath = request.getScheme() 
                        + "://"
                        + request.getServerName()
                        + ":"
                        + request.getServerPort()
                        + request.getContextPath()
                        + "/";
      %>
      <base href="<%=basePath %>" />
   </head>
   <body>
      <center>
         <h3>添加图书</h3>
         <%--
            使用GET请求没有中文乱码
         --%>
         <form action="${pageContext.request.contextPath}/book/${empty param.id ? 'save' : 'update'}">
            <%--添加图书的编号--%>
            <input type="hidden" name="id" value="${requestScope.book.id}" />
            <table>
               <tr>
                  <td>书名</td>
                  <td><input name="name" type="text"
                           value="${requestScope.book.name}"/></td>
               </tr>
               <tr>
                  <td>作者</td>
                  <td><input name="author" type="text"
                     value="${requestScope.book.author}"/></td>
               </tr>
               <tr>
                  <td>价格</td>
                  <td><input name="price" type="text"
                     value="${requestScope.book.price}"/></td>
               </tr>
               <tr>
                  <td>销量</td>
                  <td><input name="sales" type="text"
                     value="${requestScope.book.sales}"/></td>
               </tr>
               <tr>
                  <td>库存</td>
                  <td><input name="stock" type="text"
                     value="${requestScope.book.stock}"/></td>
               </tr>
               <tr>
                  <td align="center" colspan="2">
                     <input type="submit" />
                  </td>
               </tr>
            </table>
         </form>
      </center>
   </body>
</html>

BookController中的代码:

@RequestMapping(value = "/update")
public String update(Book book){
    // 调用bookService.save() 保存图书修改
    bookService.updateBook(book);
    // 重定向回图书列表管理页面
    return "redirect:/book/list";
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/590277.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

操作系统期末复习——课时八——进程同步(二)

1、信号量 信号量机制是一种功能较强的机制&#xff0c;可用来解决互斥和同步问题&#xff0c;它只能被两个标准的原语wait(S)&#xff08;P操作&#xff09;和signal(S)&#xff08;V操作 &#xff09;访问。 注意&#xff1a;原语是一种特殊的程序段&#xff0c;其执行只能一…

HNU-电子测试平台与工具2-I2C

FPGA I2C接口实现 计科210X wolf 202108010XXX 报告内容将包括: (1)如何描述组合电路、时序电路、状态机?如何编写TestBench? (2)ModelSim工具的使用; (3)EEPROM读写代码分析; (4)实验总结; 注意:其中(1)将在自定FSM中以实例的方式呈现,(2)将在(3)中提…

Java学习笔记22——异常

异常 异常异常的概述JVM处理异常的默认方案异常处理Throwable的成员方法编译时异常和运行时异常的区别异常处理throws自定义异常 异常 异常的概述 Throwable是所有异常和错误的超类 error表示严重的问题&#xff0c;合理的程序不应该试图捕获 Exception表示合理的应用想要捕…

chatgpt赋能python:Python中的{:5d}是什么?

Python中的{:5d}是什么&#xff1f; 在Python中&#xff0c;{:5d}是一种格式化字符串的方法&#xff0c;用于将整数格式化为一定宽度的字符串&#xff0c;其中{}代表占位符&#xff0c;5代表宽度&#xff0c;d代表将数据格式化为十进制整数。 简而言之&#xff0c;{:5d}的作用…

【pytest】tep环境变量、fixtures、用例三者之间的关系

tep是一款测试工具&#xff0c;在pytest测试框架基础上集成了第三方包&#xff0c;提供项目脚手架&#xff0c;帮助以写Python代码方式&#xff0c;快速实现自动化项目落地。 在tep项目中&#xff0c;自动化测试用例都是放到tests目录下的&#xff0c;每个.py文件相互独立&…

做接口测试需要哪些技能?一篇文章教你如何学会Python接口自动化测试

目录 1、什么是接口测试&#xff1f; 2、接口测试需要会什么&#xff1f; 3、如何学这些技能&#xff1f; 4、如何获取接口相关信息&#xff1f; 5、如何进行进行接口测试&#xff1f; 6、自动化接口测试 7、其他 1、什么是接口测试&#xff1f; 定义&#xff1a;测试系…

【反向面试】向你未来的软件雇主提出的36个问题

作者 | Tomas Fernandez 祝贺通过了面试&#xff01;你准备得很充分&#xff0c;并通过了所有的问题。现在你可以放松了。 "你有什么问题要问我们吗&#xff1f;” 面试官问道。哦&#xff01;这还没有结束&#xff0c;你意识到。你应该会有一些问题。 面试官并不是想让…

JVM学习(十三):面试中绕不开的String

一、String 的基本特性 1.1 String类的声明 String实现了Serializable接口&#xff0c;表示字符串是支持序列化的&#xff1b; 实现了Comparable接口&#xff0c;表示String可以比较大小 1.2 String的存储方式在jdk9中的变更 我们知道&#xff0c;String在jdk8中使用 final …

Lua学习笔记:C++操作Lua的表

前言 本篇在讲什么 C操作Lua的表(table) 本篇适合什么 适合初学Lua的小白 适合需要C/C和lua结合开发的人 本篇需要什么 对Lua语法有简单认知 对C/C语法有简单认知 依赖Lua5.1的环境 依赖VS 2017编辑器 本篇的特色 具有全流程的图文教学 重实践&#xff0c;轻理论…

23种设计模式之策略模式(Strategy Pattern)

前言&#xff1a;大家好&#xff0c;我是小威&#xff0c;24届毕业生&#xff0c;在一家满意的公司实习。本篇文章将23种设计模式中的策略模式&#xff0c;此篇文章为一天学习一个设计模式系列文章&#xff0c;后面会分享其他模式知识。 如果文章有什么需要改进的地方还请大佬不…

构建Transformer模型 | 在wikiText-2数据集上训练一个语言模型

0 Introduction CSDN上有很多关于Transformer模型代码及解析的教程&#xff0c;但总体感觉还是不够直观&#xff0c;本文来自以B站上一个公开课&#xff0c;讲得非常详细&#xff0c;建议花一点时间从头到尾跟做一遍&#xff0c;单纯看静态的代码和文字描述&#xff0c;还是比…

十大排序(四)

上几篇文章我们说的是比较类的排序&#xff0c;今天给大家分享一下非比较累的排序&#xff1b;非比较类中包含桶排序 &#xff1a;基数排序、桶排序、计数排序 计数排序 找出待排序的数组中最大和最小的元素&#xff1b; 统计数组中每个值为i的元素出现的次数&#xff0c;存入…

Azure Active Directory 的功能和优势

Azure Active Directory (Azure AD) 是 Microsoft 基于云的多租户目录和标识管理服务。 Azure AD 有助于支持用户访问资源和应用程序&#xff0c;例如&#xff1a; 位于企业网络上的内部资源和应用。 Microsoft 365、Azure 门户和 SaaS 应用程序等外部资源。 为组织开发的云应…

详解uni-app应用生命周期函数

详解uni-app应用生命周期函数 详解uni-app应用生命周期函数 文章目录 详解uni-app应用生命周期函数前言一、应用生命周期函数二、页面生命周期函数总结 前言 UNI-APP学习系列之详解uni-app应用生命周期函数 一、应用生命周期函数 函数名说明onLaunch当uni-app 初始化完成时触…

web自动化测试流程的总结及关注点

目录 一、立项后测试需要拿到的文档 二、需求评审 三、用例编写&#xff08;同时根据开发计划编写测试计划&#xff09; 四、用例评审 五、测试执行 六、测试报告及操作手册 项目的测试流程大只包含的几个阶段&#xff1a;立项、需求评审、用例评审、测试执行、测试报告文…

【PXIE301-204】基于PXIE 总线的4 路Cameralink Base 图像采集卡

产品概述&#xff1a; PXIE301‐204 一款基于3U PXI Express 总线的高性能4 路CameraLink Base 图像采集卡&#xff0c;该板卡采用Xilinx 的高性能Kintex‐7 系列FPGA 作为主控制器&#xff0c;实现PCI Express 总线接口的转换&#xff0c;图像数据的缓存&#xff0c;以及Camer…

MySQL表数据的CRUD操作

文章目录 一、CRUD二、Create1.插入基本语法2.单行数据全列插入3.多行数据指定列插入4.插入时如果冲突则更新旧值5.插入时如果冲突则替换 三、Retrieve1.查找基本语法2.全列查询2.指定列查询3.查询字段为表达式4.为查询结果指定别名5.查询结果去重6.where条件7.结果排序8.将查找…

石头剪刀步微信小程序游戏

石头剪刀步微信小程序游戏 一、概述二、选题内容三、效果四、前端源码五、后端源码 一、概述 之前接了学弟的一个课程作业&#xff0c;但是因为某些原因&#xff0c;最终换成了一个新的爬虫项目。 这个作业就是一个石头剪刀步的微信小游戏。就是与系统随机的单机PK&#xff0…

【手撕Spring源码】容器与Bean

文章目录 容器接口容器实现BeanFactory容器实现ApplicationContext容器实现 Bean的生命周期模板方法设计模式Bean后处理器BeanFactory 后处理器有关后处理器(PostProcessor)的调用时期Aware 接口 和 InitializingBean 接口初始化和销毁Scope 容器接口 此节我们要&#xff1a; 了…

人机交互学习-1 人机交互概述

人机交互概述 背景知识人机交互研究的内容人机交互的重要性用户体验用户体验的特性最佳用户体验 人机交互的发展历史人机交互与软件工程人机交互与软件工程的学科差异人机交互与软件工程的不同观点软件工程在交互式系统的缺陷人机交互对软件工程的处理人机交互与软件工程的融合…