基于JSP、java、Tomcat三者的项目实战--校园交易网(3)主页--历史清单

news2025/1/11 0:37:56

技术支持:JAVA、JSP

服务器:TOMCAT 7.0.86

编程软件:IntelliJ IDEA 2021.1.3 x64

前文几个功能的实现的博客 

基于JSP、java、Tomcat、mysql三层交互的项目实战--校园交易网(1)-项目搭建(前期准备工作)-CSDN博客

基于JSP、java、Tomcat、mysql三层交互的项目实战--校园交易网(2)登录功能实现_tomcat jsp mysql-CSDN博客

​​​​​​基于JSP、java、Tomcat三者的项目实战--校园交易网(2)注册功能实现-CSDN博客

基于JSP、java、Tomcat三者的项目实战--校园交易网(3)主页-显示清单(list)-CSDN博客

基于JSP、java、Tomcat三者的项目实战--校园交易网(3)主页--数据库也显示清单遗漏问题-CSDN博客

基于JSP、java、Tomcat三者的项目实战--校园交易网(3)主页--添加商品功能-CSDN博客

基于JSP、java、Tomcat三者的项目实战--校园交易网(3)主页--显示当前用户的信息和系统时间和实现一个简单的购物车功能,包括添加商品、增加数量、减少数量、删除商品以及计算总金额-CSDN博客

基于JSP、java、Tomcat三者的项目实战--校园交易网(3)主页--实现修改商品的名字与价格功能(万字爆更)增查改删,三端交互样样齐全-CSDN博客

基于JSP、java、Tomcat三者的项目实战--校园交易网(3)主页->处理从客户端提交过来的总金额数据,并将其存储到数据库中-CSDN博客 

 接下来,我们就来讲解这最后一个功能实现,历史清单


 网页端

Checkout.jsp

<%@ page import="entiy.Total" %>
<%@ page import="java.util.*" %>
<%@ page import="java.text.SimpleDateFormat" %>
<%@page contentType="text/html;charset=utf-8" pageEncoding="utf-8" %>
<html>
<head>
    <title>Title</title>
    <style>
        .table {
            width: 100%;
            border-collapse: collapse;
        }
        .table_header {
            background-color: lightgray;
        }
        .table td, .table th {
            border: 1px solid black;
            padding: 8px;
        }
        .button {
            padding: 10px 20px;
            background-color: #4CAF50;
            color: white;
            border: none;
            text-align: center;
            text-decoration: none;
            display: inline-block;
            font-size: 16px;
            cursor: pointer;
        }
    </style>

</head>
<body>
<h1>
    查看您的历史清单
</h1>
<h2>
    <p>
        <%
            Date date = new Date();
            SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
        %>
        <%=sdf.format(date)%>
        <br />
    </p >
</h2>
<table class="table">
    <tr class="table_header">
        <td>
            ID
        </td>
        <td>
            消费金额
        </td>
    </tr>

    <%
        List<Total> totals = (List<Total>) request.getAttribute("total");
        if (totals != null && !totals.isEmpty()) {
            for (int i = 0; i < totals.size(); i++) {
                Total e = totals.get(i);
    %>
    <tr>
        <td><%= e.getId() %></td>
        <td><%= e.getTotal() %></td>
    </tr>
    <%
        }
    } else {
    %>
    <tr>
        <td colspan="2">没有找到消费金额记录。</td>
    </tr>
    <%
        }
    %>


</table>
<p>
    <input type="button" class="button" value="返回主页面" onclick="location='list'"/>
</p >
</div>
</div>
<div id="footer">
    <div id="footer_bg">
        sdjyy@444.com
    </div>
</div>
</div>
</body>
</html>

这个网页主要是用于展示用户的消费历史清单。

  1. 使用了一个HTML表格 <table> 来展示消费历史记录。
    • 表头使用 <tr class="table_header"> 定义,显示了两列:ID 和 消费金额。
    • 使用Java代码从请求中获取 total 属性(假设是由Servlet或其他JSP传递的消费记录列表),并遍历显示每条消费记录。
  2. 条件判断和循环

    • 使用了Java中的条件判断和循环语句来动态生成HTML表格的行。
    • 如果 total 列表不为空且有内容,则通过 for 循环遍历每个 Total 对象,显示其ID和消费金额。
    • 如果 total 列表为空或没有内容,则显示一条表格行,告知用户没有找到消费金额记录。
  3. 返回按钮

    • 页面底部有一个返回按钮 <input type="button">,点击后会跳转回主页面(假设是通过相对路径 list 定义的)。
  4. 页脚

    • 最后部分有一个简单的页脚 <div id="footer">,显示了一个联系邮箱。

服务端 

TotalServlet

package Servlet;

import dao.StudentDAO;
import entiy.Product;
import entiy.Total;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.PrintWriter;

public class TotalServlet extends HttpServlet {
    public void service(HttpServletRequest request,
                        HttpServletResponse response)

            throws ServletException, IOException {
        request.setCharacterEncoding("utf-8");
        String total = request.getParameter("total");
        response.setContentType("text/html;charset=utf-8");
        PrintWriter out=response.getWriter();
        try {
            StudentDAO dao = new StudentDAO();
           Total e1 = new Total();
            e1.setTotal(Double.parseDouble(total));

            System.out.println(e1.getTotal());
            dao.totalprice(e1);
            response.sendRedirect("list");
        } catch (Exception e) {
            e.printStackTrace();
            out.println("系统繁忙,请稍后再试!");
        }
        out.close();
    }
}

主要功能是接收来自前端的请求,获取消费总额信息,然后将其存储到数据库中,并最终重定向到另一个页面以显示存储的消费总额列表。

  1. 服务方法 (service 方法)

    • service 方法是Servlet的核心方法,在接收到HTTP请求时被调用。
    • 首先设置请求字符编码为UTF-8,以确保能正确处理中文字符。
    • 使用 request.getParameter("total") 获取名为 "total" 的请求参数,该参数通常是前端页面提交的消费总额数据。
    • 设置响应的内容类型为 text/html;charset=utf-8,并获取响应输出流 PrintWriter out,以便向客户端输出响应。
  2. 业务逻辑处理

    • 在 try 块中,创建 StudentDAO 对象 dao,用于访问数据库。
    • 创建一个新的 Total 对象 e1,用于封装消费总额信息。
    • 将从请求参数获取的消费总额数据 total 转换为 double 类型,并设置到 e1 对象中。
    • 调用 dao.totalprice(e1) 方法,将 e1 对象传递给 StudentDAO 对象,实现将消费总额存储到数据库中的操作。
  3. 异常处理

    • 如果在数据库操作过程中发生异常,捕获并打印异常堆栈信息,并向客户端输出简单的错误信息 "系统繁忙,请稍后再试!"。
  4. 响应处理

    • 最后调用 response.sendRedirect("list") 方法,重定向到名为 "list" 的页面(假设这是一个展示消费总额列表的页面)。
    • 关闭输出流 out,释放资源。

这段代码通过Servlet接收前端的HTTP请求,从请求中获取消费总额数据,将其封装成对象并存储到数据库中,处理可能出现的异常情况,并将用户重定向到展示消费总额列表的页面。它展示了在Web应用中如何使用Servlet处理用户请求、访问数据库,并进行简单的异常处理和页面重定向操作。

dao层

totalprice

public void totalprice(Total e) throws Exception {
        Connection conn = null;
        PreparedStatement prep = null;
        try {
            conn = DBUtil.getConnection();
            prep = conn.prepareStatement(
                    "INSERT INTO Total (total) VALUES (?)");
            prep.setDouble(1, e.getTotal());
            prep.executeUpdate();
        } catch (Exception e1) {
            e1.printStackTrace();
            throw e1;
        } finally {
            // Close PreparedStatement and Connection
            if (prep != null) {
                try {
                    prep.close();
                } catch (SQLException e2) {
                    e2.printStackTrace();
                }
            }
            DBUtil.close(conn);
        }
    }

这是 StudentDAO 类中的 totalprice 方法,用于将消费总额数据插入到数据库中的 Total 表中

  1. 数据库连接和准备语句设置

    • Connection conn 和 PreparedStatement prep 被声明为 null,用于建立数据库连接和执行预编译的SQL语句。
    • 在 try 块中,通过 DBUtil.getConnection() 获取数据库连接 conn
    • 使用 conn.prepareStatement() 方法准备 SQL 语句 "INSERT INTO Total (total) VALUES (?)",其中 ? 是一个占位符,用于接受传入的消费总额数据。
  2. 设置参数和执行更新

    • 调用 prep.setDouble(1, e.getTotal()) 将 Total 对象 e 中的消费总额值设置到 SQL 语句的第一个参数位置。
    • 使用 prep.executeUpdate() 执行更新操作,将消费总额数据插入到数据库的 Total 表中。
  3. 异常处理

    • 在 try 块中捕获可能抛出的异常,如果发生异常,则会在控制台打印异常堆栈信息 (e1.printStackTrace())。
    • catch 块中再次抛出捕获到的异常 e1,以便让调用者进一步处理或通知错误。
  4. 资源释放

    • finally 块用于确保资源的释放,即使在发生异常时也能执行到。
    • 在 finally 块中,关闭 PreparedStatement 对象 prep,释放数据库连接 conn
  5. 数据库连接和关闭

    • 在 finally 块中,检查并关闭 prep 对象,避免资源泄漏。
    • 调用 DBUtil.close(conn) 方法关闭数据库连接 conn,确保释放数据库连接资源。

这段代码负责将传入的消费总额数据存储到数据库的 Total 表中。它利用了预编译的 PreparedStatement 来执行 SQL 插入操作,通过 DBUtil 类提供的方法获取和关闭数据库连接,确保了资源的有效管理和异常情况的处理。

 Total类

package entiy;

public class Total {
    private double total;
    private int id;

    public void setId(int id) {
        this.id = id;
    }

    public int getId() {
        return id;
    }

    public Total(/*, 其他属性 */) {
        this.total = total;
        this.id = id;
        // 初始化其他属性
    }

    public void setTotal(double total) {
        this.total = total;
    }

    public double getTotal() {
        return total;
    }

    @Override
    public String toString() {
        return "Total{" +
                "total=" + total +
                ", id=" + id +
                '}';
    }
}

web.xml
 

 <servlet>
        <servlet-name>total</servlet-name>
        <servlet-class>Servlet.TotalServlet</servlet-class>
    </servlet>
    <servlet-mapping>
        <servlet-name>total</servlet-name>
        <url-pattern>/total</url-pattern>
    </servlet-mapping>


LSQDServlet

package Servlet;

import dao.StudentDAO;
import entiy.Total;

import javax.servlet.RequestDispatcher;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.PrintWriter;
import java.util.List;

public class LSQDServlet extends HttpServlet {
    public void service(HttpServletRequest request,
                        HttpServletResponse response)
            throws ServletException, IOException {
        response.setContentType("text/html;charset=utf-8");
        PrintWriter out = response.getWriter();
        try {
            StudentDAO dao = new StudentDAO();
            List<Total> totals = dao.findtotals();
            request.setAttribute("total",totals);
            RequestDispatcher rd = request.getRequestDispatcher("Checkout.jsp");
            rd.forward(request,response);
        } catch (Exception e) {
            e.printStackTrace();
            out.println("系统繁忙,请稍后再试!");
        }
    }
}

 主要是用于处理HTTP请求并将消费总额数据传递到JSP页面进行显示。

 

  1. service 方法

    • 设置响应的内容类型为 text/html;charset=utf-8
    • 获取 PrintWriter 对象,用于输出响应内容。
    • 在 try-catch 块中处理请求:
      • 创建一个 StudentDAO 对象 dao,用于访问数据库。
      • 调用 dao.findtotals() 方法获取消费总额的列表数据,并将结果存储在 List<Total> totals 中。
      • 使用 request.setAttribute("total", totals) 将获取到的消费总额列表设置为请求属性,以便传递给JSP页面。
      • 获取 RequestDispatcher 对象 rd,并使用 rd.forward(request, response) 将请求转发到名为 Checkout.jsp 的JSP页面,实现了数据和控制的分离。
  2. 异常处理

    • 如果在数据库访问或转发过程中发生异常,会打印异常堆栈信息,并向输出流 out 写入一条系统繁忙的错误信息。
  3. JSP 页面的处理

    • JSP页面(假设为 Checkout.jsp)会根据 request.getAttribute("total") 获取到的消费总额列表数据,动态生成HTML内容展示给用户。

这段代码的主要逻辑是通过Servlet从数据库中获取消费总额数据,并将其传递到JSP页面进行展示,实现了MVC(Model-View-Controller)模式中的控制器(Controller)部分。

dao层

findTotal

public List<Total> findtotals() throws Exception {
        List<Total> totals = new ArrayList<Total>();
        Connection conn = null;
        PreparedStatement prep = null;
        ResultSet rst = null;
        try {
            conn = DBUtil.getConnection();
            prep = conn.prepareStatement("select * from Total");
            rst = prep.executeQuery();
            while (rst.next()){
                int id = rst.getInt("id");
                double total = rst.getDouble("total");
                Total e1 = new Total();
                System.out.println(e1);
                e1.setId(id);
                e1.setTotal(total);
                totals.add(e1);
            }
        } catch (Exception e) {
            e.printStackTrace();
            throw  e;
        }finally {
            DBUtil.close(conn);
        }

        return totals;
    }

这段代码是 StudentDAO 类中的 findtotals() 方法实现,用于从数据库中查询消费总额数据并返回一个 List<Total> 对象。

  1. 方法签名

    • 返回类型为 List<Total>,表示消费总额的集合。
    • 方法名为 findtotals(),没有参数。
    • 方法可能会抛出 Exception 异常,表示可能会处理各种数据库操作中可能发生的异常情况。
  2. 方法实现

    • 创建一个空的 ArrayList 对象 totals,用于存储从数据库查询到的消费总额数据。
    • 声明数据库连接对象 conn、预处理语句对象 prep 和结果集对象 rst,并初始化为 null
  3. 数据库操作

    • 在 try 块中:
      • 调用 DBUtil.getConnection() 获取数据库连接对象 conn
      • 使用连接对象 conn 创建预处理语句 prep,并执行 SQL 查询语句 "select * from Total",将结果存储在结果集 rst 中。
      • 使用 while 循环遍历结果集 rst,每次迭代:
        • 从结果集中获取 id 和 total 字段的值。
        • 创建一个新的 Total 对象 e1
        • 设置 e1 的 id 和 total 属性。
        • 将 e1 添加到 totals 集合中。
  4. 异常处理

    • 如果在数据库连接、预处理语句创建、查询执行过程中发生异常,将会打印异常堆栈信息,并将异常继续抛出。
  5. 资源释放

    • 在 finally 块中调用 DBUtil.close(conn) 方法关闭数据库连接,确保资源被正确释放。
  6. 返回结果

    • 返回存储了从数据库中查询到的消费总额数据的 totals 集合。

这段代码的主要功能是执行一个简单的数据库查询操作,将查询到的消费总额数据封装成 Total 对象,并将这些对象存储在一个列表中返回。

 Total类

package entiy;

public class Total {
    private double total;
    private int id;

    public void setId(int id) {
        this.id = id;
    }

    public int getId() {
        return id;
    }

    public Total(/*, 其他属性 */) {
        this.total = total;
        this.id = id;
        // 初始化其他属性
    }

    public void setTotal(double total) {
        this.total = total;
    }

    public double getTotal() {
        return total;
    }

    @Override
    public String toString() {
        return "Total{" +
                "total=" + total +
                ", id=" + id +
                '}';
    }
}

web.xml
 

<servlet>
        <servlet-name>LSQD</servlet-name>
        <servlet-class>Servlet.LSQDServlet</servlet-class>
    </servlet>
    <servlet-mapping>
        <servlet-name>LSQD</servlet-name>
        <url-pattern>/LSQD</url-pattern>
    </servlet-mapping>

 

 

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

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

相关文章

工具学习_CVE Binary Tool

1. 工具概述 CVE Binary Tool 是一个免费的开源工具&#xff0c;可帮助您使用国家漏洞数据库&#xff08;NVD&#xff09;常见漏洞和暴露&#xff08;CVE&#xff09;列表中的数据以及Redhat、开源漏洞数据库&#xff08;OSV&#xff09;、Gitlab咨询数据库&#xff08;GAD&am…

鸿蒙AI功能开发【人脸活体验证控件】 机器学习-场景化视觉服务

人脸活体验证控件 介绍 本示例展示了使用视觉类AI能力中的人脸活体验证能力。 本示例模拟了在应用里&#xff0c;跳转人脸活体验证控件&#xff0c;获取到验证结果并展示出来。 需要使用hiai引擎框架人脸活体验证接口kit.VisionKit.d.ts。 效果预览 使用说明&#xff1a; …

RK3568平台开发系列讲解(文件系统篇)文件描述符 fd(File Descriptor)是什么?

📢USB控制传输是USB通信中的一种基本传输类型,用于控制USB设备的配置和操作。它由 Setup 阶段和 Data 阶段组成,可用于发送命令、读取状态、配置设备等操作。 一、文件描述符 fd(File Descriptor)是什么? 文件描述符 fd 是一个非负整数,用来标识一个打开的文件,由内核…

用户态tcp协议栈四次挥手-服务端发送fin时,客户端不返回ac

问题&#xff1a; 四次挥手时&#xff0c;服务端发送fin后&#xff0c;客户端不发送ack&#xff0c;反而过了2min后发了个rst报文 62505是客户端&#xff0c;8889是服务端 解决&#xff1a; 服务端返回fin报文时带上ack标记

微波武器反无人机技术详解

微波武器反无人机技术中展现出了独特的优势和广阔的应用前景。以下是对微波武器在反无人机技术方面的详细解析&#xff1a; 一、微波武器概述 微波武器是指配备高功率微波&#xff08;High-Power Microwave, HPM&#xff09;载荷的作战武器&#xff0c;能够发射高能量的电磁脉…

在AI浪潮中保持核心竞争力:XIAOJUSURVEY的智能化探索

讲点实在的 在AI技术快速发展的今天&#xff0c;各行各业的工作方式正经历深刻变革。尤其是身处浪潮中甚至最有机会推动发展的我们&#xff0c;更需要置身事内。 ChatGPT、Copilot等的普及&#xff0c;使得编程效率显著提升&#xff0c;但也带来了新的挑战。为了在这种变革中…

C++输出为非科学计数法不同数据类型表示范围

目录 一、C数据类型 1、基本的内置类型 2、修饰符 &#xff08;1&#xff09;signed 和 unsigned &#xff08;2&#xff09;short 和 long &#xff08;3&#xff09;区别总结 默认情况 二、类型转换 1、静态转换&#xff08;Static Cast&#xff09; 2、动态转换&a…

C语言——函数(1)

函数 定义&#xff1a; 函数就是用来完成一定功能的一段代码&#xff08;程序&#xff09;模块。 在设计较大的程序时&#xff0c;一般将其分为若干个程序模块&#xff0c;每个模块用来实现一定的功能。 函数优势&#xff1a; 我们可以通过函数提供功能给别人使用&#xff0c…

美国商超入驻Homedepot,传统家织厂家跨境赛道新选择?——WAYLI威利跨境助力商家

美国商超入驻Homedepot为传统家织厂家提供了新跨境选择。据《Interactive Home Shopping》一文&#xff0c;电子购物让消费者更易定位和比较产品。传统家织厂家可通过Homedepot等大型零售商&#xff0c;利用其平台优势&#xff0c;接触更广泛消费者。 根据《Homedepot之争——家…

【八股文】Redis

1.Redis有哪些数据类型 常用的数据类型&#xff0c;String&#xff0c;List&#xff0c;Set&#xff0c;Hash和ZSet&#xff08;有序&#xff09; String&#xff1a;Session&#xff0c;Token&#xff0c;序列化后的对象存储&#xff0c;BitMap也是用的String类型&#xff0c;…

案例:LVS+Keepalived集群

目录 Keepalived 原理 Keepalived案例 双机高可用热备案例 配置 修改配置文件 测试 严格模式测试 修改配置文件 测试 模拟故障测试 LVSKeepalived高可用 案例拓扑图 初步配置 关闭服务 主调度器配置 健康状态检查的方式 调整内核参数 从调度器配置 服务器池…

失业后才会明白,职场上有4个扎心的现象

最近一段时间&#xff0c;因为疫情的原因&#xff0c;很多企业都在经历着前所未有的困难&#xff0c;其中就包括华为这样的大型企业。 任正非在接受媒体采访的时候表示&#xff1a;“全球经济持续衰退&#xff0c;未来3到5年内都不可能转好……把寒气传递给每个人。 这句话一…

python中的魔术方法(特殊方法)

文章目录 1. 前言2. __init__方法3. __new__方法4. __call__方法5. __str__方法6. __repr__方法7. __getitem__方法8. __setitem__方法9. __delitem__方法10. __len__方法11. 富比较特殊方法12. __iter__方法和__next__方法13. __getattr__方法、__setattr__方法、__delattr__方…

深度学习DeepLearning Inference 学习笔记

神经网络预测 术语 隐藏层神经元多层感知器 神经网络概述 应当选择正确的隐藏层数和每层隐藏神经元的数量&#xff0c;以达到这一层的输出是下一层的输入&#xff0c;逐层变得清晰&#xff0c;最终输出数据的目的。 在人脸识别的应用中&#xff0c;我们将图片视作连续的像…

【Java 第九篇章】多线程实际工作中的头大的模块

多线程是一种编程概念&#xff0c;它允许多个执行路径&#xff08;线程&#xff09;在同一进程内并发运行。 一、多线程的概念和作用 1、概念 线程是程序执行的最小单元&#xff0c;一个进程可以包含多个线程。每个线程都有自己的程序计数器、栈和局部变量&#xff0c;但它们…

Motionface ai工具有哪些?

Motionface Android/PC 用一张静态含有人脸相片来生成一个能说会唱的虚拟主播。使用简单便捷&#xff0c;极致的流畅度体验超乎您的想象。 免费下载 Respeak PC电脑软件 任意视频一键生成虚拟主播&#xff0c;匹配音频嘴型同步&#xff0c;保留原视频人物神态和动作&#xff0c…

核显硬刚RTX 4070,AMD全新APU杀疯了

这年头&#xff0c;一台平民玩家低预算主流桌面电脑主机是什么配置&#xff1f; Intel i5 12400F CPU、B760 主板、NVIDIA RTX 4060 显卡、双 8G DDR4 内存、1T 固态硬盘的组合&#xff0c;想必相当具有代表性了吧&#xff01; 但仔细掰开后我们不难发现&#xff0c;这套不到…

生物信息学入门:Linux学习指南

还没有使用过生信云服务器&#xff1f;快来体验一下吧 20核心256G内存最低699元半年。 更多访问 https://ad.tebteb.cc 介绍 大家好&#xff01;作为一名生物信息学的新人&#xff0c;您可能对Linux感到陌生&#xff0c;但别担心&#xff0c;本教程将用简单明了的方式&#xff…

Cache结构

Cache cache的一般设计 超标量处理器每周期需要从Cache中同时读取多条指令&#xff0c;同时每周期也可能有多条load/store指令会访问Cache&#xff0c;因此需要多端口的Cache L1 Cache&#xff1a;最靠近处理器&#xff0c;是流水线的一部分&#xff0c;包含两个物理存在 指…

解决windows安装docker desktop打开报错问题

下载docker windows版本: https://desktop.docker.com/win/main/amd64/Docker%20Desktop%20Installer.exe?utm_sourcedocker&utm_mediumwebreferral&utm_campaigndd-smartbutton&utm_locationmodule 正常安装&#xff0c;然后运行&#xff0c;弹出这个报错: 试了…