java程序设计与j2ee中间件技术/软件开发技术(III)-大作业-采用MVC模式实现商品信息的查询显示(可以模糊查询)、增加和删除功能,商品表自拟,实现简单菜单操作和分页显示(三)

简介: java程序设计与j2ee中间件技术/软件开发技术(III)-大作业-采用MVC模式实现商品信息的查询显示(可以模糊查询)、增加和删除功能,商品表自拟,实现简单菜单操作和分页显示

src/main/java/util

JDBCUtil.java

package util;
import java.io.FileInputStream;
import java.io.InputStream;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.Properties;
import javax.sql.DataSource;
import com.mchange.v2.c3p0.ComboPooledDataSource;
public class JDBCUtil {
  static ComboPooledDataSource dataSource = null;
  static{
    dataSource = new ComboPooledDataSource();
  }
  public static DataSource getDataSource(){
    return dataSource;
  }
  /**
   * 获取连接对象
   */
  public static Connection getConn() throws SQLException{
    return dataSource.getConnection();
  }
  /**
   * 释放资源
   */
  public static void release(Connection conn , Statement st , ResultSet rs){
    closeRs(rs);
    closeSt(st);
    closeConn(conn);
  }
  public static void release(Connection conn , Statement st){
    closeSt(st);
    closeConn(conn);
  }
  private static void closeRs(ResultSet rs){
    try {
      if(rs != null){
        rs.close();
      }
    } catch (SQLException e) {
      e.printStackTrace();
    }finally{
      rs = null;
    }
  }
  private static void closeSt(Statement st){
    try {
      if(st != null){
        st.close();
      }
    } catch (SQLException e) {
      e.printStackTrace();
    }finally{
      st = null;
    }
  }
  private static void closeConn(Connection conn){
    try {
      if(conn != null){
        conn.close();
      }
    } catch (SQLException e) {
      e.printStackTrace();
    }finally{
      conn = null;
    }
  }
}

TextUtil.java

package util;
public class TextUtil {
  /**
   * 判断某一个字符串是否为空。
   */
  public static boolean isEmpty(CharSequence s){
    return s==null || s.length() == 0;
  }
}

src/main/webapp

src/main/webapp/WEB-INF

web.xml

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://xmlns.jcp.org/xml/ns/javaee" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd" version="3.1">
  <display-name>ch7_test</display-name>
  <welcome-file-list>
    <welcome-file>index.html</welcome-file>
    <welcome-file>index.htm</welcome-file>
    <welcome-file>index.jsp</welcome-file>
    <welcome-file>default.html</welcome-file>
    <welcome-file>default.htm</welcome-file>
    <welcome-file>default.jsp</welcome-file>
  </welcome-file-list>
  <servlet>
      <servlet-name>addServlet</servlet-name>
      <servlet-class>AddServlet</servlet-class>
  </servlet>
  <servlet-mapping>
    <servlet-name>addServlet</servlet-name>
    <url-pattern>/AddServlet</url-pattern>
  </servlet-mapping>
    <servlet>
      <servlet-name>showServlet</servlet-name>
      <servlet-class>ShowServlet</servlet-class>
  </servlet>
  <servlet-mapping>
    <servlet-name>showServlet</servlet-name>
    <url-pattern>/ShowServlet</url-pattern>
  </servlet-mapping>
    <servlet>
      <servlet-name>deleteServlet</servlet-name>
      <servlet-class>servlet.DeleteServlet</servlet-class>
  </servlet>
  <servlet-mapping>
    <servlet-name>deleteServlet</servlet-name>
    <url-pattern>/DeleteServlet</url-pattern>
  </servlet-mapping>
   <servlet>
      <servlet-name>goodsListPageServlet</servlet-name>
      <servlet-class>servlet.GoodsListPageServlet</servlet-class>
  </servlet>
  <servlet-mapping>
    <servlet-name>goodsListPageServlet</servlet-name>
    <url-pattern>/GoodsListPageServlet</url-pattern>
  </servlet-mapping>
  <servlet>
      <servlet-name>goodsListServlet</servlet-name>
      <servlet-class>servlet.GoodsListServlet</servlet-class>
  </servlet>
  <servlet-mapping>
    <servlet-name>goodsListServlet</servlet-name>
    <url-pattern>/GoodsListServlet</url-pattern>
  </servlet-mapping>
    <servlet>
      <servlet-name>searchGoodsServlet</servlet-name>
      <servlet-class>servlet.SearchGoodsServlet</servlet-class>
  </servlet>
  <servlet-mapping>
    <servlet-name>searchGoodsServlet</servlet-name>
    <url-pattern>/SearchGoodsServlet</url-pattern>
  </servlet-mapping>  
</web-app>

add.jsp

<%@ page contentType="text/html;charset=UTF-8" %>
<html>
  <head>
    <title>register.jsp</title>
  </head>
  <body>
  <jsp:include page="head.jsp" flush="true"/>
  <font size=3>
    <h1>请添加商品</h1>
    <form action="AddServlet" method="get">
    <table>
        <tr>
          <td>商品名:</td>
          <td><input type="text" name="gname"></td>
        </tr>
        <tr>
          <td>价格:</td>  
          <td><input type="text" name="price"></td>
        </tr>
        <tr>
        <td><input type="submit" value="提交"></td>
      </tr>
    </table>
    </form>
    </font>
    <script>
     var Null= '<%=request.getParameter("Null")%>';
    if(Null=='yes'){
        alert("信息不得为空!");
    }
    </script>
  </body>
</html>

head.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<%
    String col = request.getParameter("col");
%>
<link href="style.css" rel="stylesheet" type="text/css"/>
<div id="top" class="layout">
    <img src="logo.jpg" width="100" height="100">
</div>
<div id="nav" class="layout">
<ul>
    <li><a href="add.jsp">增加商品</a></li>
    <li><a href="GoodsListPageServlet?currentPage=1">显示商品</a></li>
    </ul>
</div>

list.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
    <%@page import="bean.*" %>
    <%@page import="java.util.*" %>
 <%@ 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>
<script type="text/javascript">
  function doDelete(sid) {
    /* 如果这里弹出的对话框,用户点击的是确定,就马上去请求Servlet。 
    如何知道用户点击的是确定。
    如何在js的方法中请求servlet。 */
    var flag = confirm("是否确定删除?");
    if(flag){
      location.href="DeleteServlet?id="+id;
    }
  }
</script>
</head>
<body>
  <jsp:include page="head.jsp"></jsp:include>
  <form action="SearchStudentServlet" method="post">
    <table border="1" width="700">
      <tr >
        <td colspan="8">
          按名称查询:<input type="text" name="gname"/>
          &nbsp;
          按价格查询:<input type="text" name="price"/>
          &nbsp;&nbsp;&nbsp;
          <input type="submit" value="查询">
          &nbsp;&nbsp;&nbsp;
          <a href="add.jsp">添加</a>
        </td>
      </tr>
      <tr align="center">
      <td>编号</td>
      <td>商品名</td>
      <td>价格</td>
      </tr>
        <c:forEach items="${pageBean.list }" var="goods">
          <tr align="center">
          <td>${goods.id }</td>
          <td>${goods.gname }</td>
          <td>${goods.data}</td>
          <td><a href="#" onclick="doDelete(${goods.id})">删除</a></td>
          </tr>
        </c:forEach>
      </table>
    </form>
</body>
</html>

list_page.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>
<script type="text/javascript">
  function doDelete(sid) {
    /* 如果这里弹出的对话框,用户点击的是确定,就马上去请求Servlet。 
    如何知道用户点击的是确定。
    如何在js的方法中请求servlet。 */
    var flag = confirm("是否确定删除?");
    if(flag){
      //表明点了确定。 访问servlet。 在当前标签页上打开 超链接,
      //window.location.href="DeleteServlet?sid="+sid;
      location.href="DeleteServlet?id="+id;
    }
  }
</script>
</head>
<body>
  <jsp:include page="head.jsp"></jsp:include>
  <form action="SearchStudentServlet" method="post">
    <table border="1" width="700">
      <tr >
        <td colspan="8">
          按名称查询:<input type="text" name="gname"/>
          &nbsp;
          按价格查询:<input type="text" name="price"/>
          &nbsp;&nbsp;&nbsp;
          <input type="submit" value="查询">
          &nbsp;&nbsp;&nbsp;
          <a href="add.jsp">添加</a>
        </td>
      </tr>
      <tr align="center">
      <td>编号</td>
      <td>商品名</td>
      <td>价格</td>
      </tr>
        <c:forEach items="${pageBean.list }" var="goods">
          <tr align="center">
          <td>${goods.id }</td>
          <td>${goods.gname }</td>
          <td>${goods.price }</td>
          <td><a href="#" onclick="doDelete(${goods.id})">删除</a></td>
          </tr>
        </c:forEach>
        <tr>
          <td colspan="8">
            第 ${pageBean.currentPage } / ${pageBean.totalPage }
            &nbsp;&nbsp;
            每页显示${pageBean.pageSize }条  &nbsp;&nbsp;&nbsp;
            总的记录数${pageBean.totalSize } &nbsp;&nbsp;&nbsp;
            <c:if test="${pageBean.currentPage !=1 }">
              <a href="StudentListPageServlet?currentPage=1">首页</a>
            | <a href="StudentListPageServlet?currentPage=${pageBean.currentPage-1 }">上一页</a>
            </c:if>
        <c:forEach items="${pageBean.list }" var="goods">
          <tr align="center">
          <td>${goods.id }</td>
          <td>${goods.gname }</td>
          <td>${goods.price }</td>
          <td><a href="#" onclick="doDelete(${goods.id})">删除</a></td>
          </tr>
        </c:forEach>
            <c:if test="${pageBean.currentPage !=pageBean.totalPage }">
              <a href="StudentListPageServlet?currentPage=${pageBean.currentPage+1 }">下一页</a> | 
              <a href="StudentListPageServlet?currentPage=${pageBean.totalPage }">尾页</a>
            </c:if>
          </td>
        </tr>
      </table>
    </form>
</body>
</html>

main.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>
</head>
<body>
  <jsp:include page="head.jsp" flush="true"/>
</body>
</html>

style.css

*{  
  margin: 0 ;
  padding: 0;
}
nav{  
  text-align: center; 
  /*margin:0px auto;   /*没有宽度不能居中*/ 
}
ul{
  display: inline-block;/*ul设为内联元素便于居中*/  
}
 ul li{
  float: left;
  list-style-type: none;  /*去掉圆点*/
}
 ul li + li{
  border-left: 1px solid #333;
}
 ul li a{
  background: #999;
    text-align: center;
  text-decoration: none;
  color: #000;
  display: block;
  padding: 3px 10px;
}
 ul li a:hover{
  color: red;
  background: #333;
  cursor: pointer;
}
目录
相关文章
|
5月前
|
监控 Cloud Native Java
Quarkus 云原生Java框架技术详解与实践指南
本文档全面介绍 Quarkus 框架的核心概念、架构特性和实践应用。作为新一代的云原生 Java 框架,Quarkus 旨在为 OpenJDK HotSpot 和 GraalVM 量身定制,显著提升 Java 在容器化环境中的运行效率。本文将深入探讨其响应式编程模型、原生编译能力、扩展机制以及与微服务架构的深度集成,帮助开发者构建高效、轻量的云原生应用。
615 44
|
5月前
|
安全 Java API
Java Web 在线商城项目最新技术实操指南帮助开发者高效完成商城项目开发
本项目基于Spring Boot 3.2与Vue 3构建现代化在线商城,涵盖技术选型、核心功能实现、安全控制与容器化部署,助开发者掌握最新Java Web全栈开发实践。
550 1
|
6月前
|
安全 Java 编译器
new出来的对象,不一定在堆上?聊聊Java虚拟机的优化技术:逃逸分析
逃逸分析是一种静态程序分析技术,用于判断对象的可见性与生命周期。它帮助即时编译器优化内存使用、降低同步开销。根据对象是否逃逸出方法或线程,分析结果分为未逃逸、方法逃逸和线程逃逸三种。基于分析结果,编译器可进行同步锁消除、标量替换和栈上分配等优化,从而提升程序性能。尽管逃逸分析计算复杂度较高,但其在热点代码中的应用为Java虚拟机带来了显著的优化效果。
200 4
|
6月前
|
Java API Maven
2025 Java 零基础到实战最新技术实操全攻略与学习指南
本教程涵盖Java从零基础到实战的全流程,基于2025年最新技术栈,包括JDK 21、IntelliJ IDEA 2025.1、Spring Boot 3.x、Maven 4及Docker容器化部署,帮助开发者快速掌握现代Java开发技能。
1218 1
|
7月前
|
人工智能 Java
Java多任务编排技术
JDK 5引入Future接口实现异步任务处理,但获取结果不够灵活。Java 8新增CompletableFuture,实现异步任务编排,支持流式处理、多任务组合及异常处理,提升执行效率与代码可读性,简化并发编程复杂度。
164 0
|
6月前
|
Java 测试技术 API
2025 年 Java 开发者必知的最新技术实操指南全览
本指南涵盖Java 21+核心实操,详解虚拟线程、Spring Boot 3.3+GraalVM、Jakarta EE 10+MicroProfile 6微服务开发,并提供现代Java开发最佳实践,助力开发者高效构建高性能应用。
940 4
|
5月前
|
安全 Cloud Native Java
Java 模块化系统(JPMS)技术详解与实践指南
本文档全面介绍 Java 平台模块系统(JPMS)的核心概念、架构设计和实践应用。作为 Java 9 引入的最重要特性之一,JPMS 为 Java 应用程序提供了强大的模块化支持,解决了长期存在的 JAR 地狱问题,并改善了应用的安全性和可维护性。本文将深入探讨模块声明、模块路径、访问控制、服务绑定等核心机制,帮助开发者构建更加健壮和可维护的 Java 应用。
399 0
|
6月前
|
JavaScript 安全 前端开发
Java开发:最新技术驱动的病人挂号系统实操指南与全流程操作技巧汇总
本文介绍基于Spring Boot 3.x、Vue 3等最新技术构建现代化病人挂号系统,涵盖技术选型、核心功能实现与部署方案,助力开发者快速搭建高效、安全的医疗挂号平台。
333 3
|
7月前
|
存储 Java Linux
操作系统层面视角下 Java IO 的演进路径及核心技术变革解析
本文从操作系统层面深入解析Java IO的演进历程,涵盖BIO、NIO、多路复用器及Netty等核心技术。分析各阶段IO模型的原理、优缺点及系统调用机制,探讨Java如何通过底层优化提升并发性能与数据处理效率,全面呈现IO技术的变革路径与发展趋势。
160 3
|
7月前
|
安全 Java 微服务
Java 最新技术和框架实操:涵盖 JDK 21 新特性与 Spring Security 6.x 安全框架搭建
本文系统整理了Java最新技术与主流框架实操内容,涵盖Java 17+新特性(如模式匹配、文本块、记录类)、Spring Boot 3微服务开发、响应式编程(WebFlux)、容器化部署(Docker+K8s)、测试与CI/CD实践,附完整代码示例和学习资源推荐,助你构建现代Java全栈开发能力。
794 1