Servlet+JDBC实战开发书店项目讲解第三篇:商品查询实现

2023-11-09

Servlet+JDBC实战开发书店项目讲解第三篇:商品查询实现

本篇博客将介绍如何在Servlet+JDBC实战开发书店项目中实现商品查询功能。我们将从设计数据库表结构和实体类开始,一步一步详细讲解代码实现过程,包括前端页面的设计和后端Servlet代码的编写。通过本文的学习,您将能够理解并实践商品查询功能的开发。

第一步:数据库表设计和实体类创建

首先,我们需要设计数据库表结构来存储商品信息,并创建相应的实体类。

在数据库中创建一个名为products的表,包含以下字段:

  • id:商品ID,类型为整型,主键
  • name:商品名称,类型为字符串
  • price:商品价格,类型为浮点数
  • description:商品描述,类型为字符串

接下来,创建一个Java类Product作为商品的实体类。该类需要包含与数据库表中字段对应的属性,并提供相应的getter和setter方法。

public class Product {
    private int id;
    private String name;
    private double price;
    private String description;

    // Constructor, getters and setters
}

第二步:创建商品查询页面的HTML和CSS

在这一步,我们将创建一个商品查询页面,让用户可以输入查询条件并点击按钮进行查询。

<!DOCTYPE html>
<html>
<head>
    <title>商品查询</title>
    <link rel="stylesheet" type="text/css" href="styles.css">
</head>
<body>
    <h1>商品查询</h1>
    <form action="ProductSearchServlet" method="get">
        <label for="productName">商品名称:</label>
        <input type="text" id="productName" name="name" required>
        <br><br>
        <label for="productPrice">商品价格:</label>
        <input type="number" id="productPrice" name="price">
        <br><br>
        <input type="submit" value="查询">
    </form>
</body>
</html>

在上述示例中,我们创建了一个简单的HTML表单,用户可以输入商品名称和价格来进行查询。我们还引入了一个样式表styles.css来美化页面的外观。

第三步:实现后端Servlet代码

接下来,我们将编写后端的Servlet代码,来处理用户的查询请求,并返回查询结果。

首先,创建一个名为ProductSearchServlet的Java类,继承HttpServlet类,并覆盖doGet()方法。

@WebServlet("/ProductSearchServlet")
public class ProductSearchServlet extends HttpServlet {
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        // 获取用户输入的查询条件
        String name = request.getParameter("name");
        double price = Double.parseDouble(request.getParameter("price"));

        // 构建SQL查询语句
        String sql = "SELECT * FROM products WHERE name LIKE ? AND price <= ?";

        try {
            // 执行查询并获取结果集
            Connection conn = DBUtil.getConnection();
            PreparedStatement statement = conn.prepareStatement(sql);
            statement.setString(1, "%" + name + "%");
            statement.setDouble(2, price);
            ResultSet resultSet = statement.executeQuery();

            // 将结果集转化为商品对象列表
            List<Product> productList = new ArrayList<>();
            while (resultSet.next()) {
                Product product = new Product();
                product.setId(resultSet.getInt("id"));
                product.setName(resultSet.getString("name"));
                product.setPrice(resultSet.getDouble("price"));
                product.setDescription(resultSet.getString("description"));
                productList.add(product);
            }

            // 将商品列表传递给前端页面
            request.setAttribute("products", productList);
            request.getRequestDispatcher("productlist.jsp").forward(request, response);

            conn.close();
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }
}

在上述代码中,我们首先从HttpServletRequest中获取用户输入的查询条件,然后构建SQL查询语句。接下来,我们通过执行SQL查询操作,并将结果集转化为商品对象列表。最后,我们将商品列表存储到请求属性中,并转发到名为productlist.jsp的JSP页面以进行展示。

第四步:创建商品列表展创建HTML页面

首先,在项目中创建一个名为 product_query.html 的 HTML 页面。在页面中添加以下代码:

<!DOCTYPE html>
<html>
<head>
    <title>商品查询</title>
    <style>
        table {
            border-collapse: collapse;
            width: 100%;
        }

        th, td {
            border: 1px solid black;
            padding: 8px;
        }

        th {
            background-color: #f2f2f2;
        }

        input[type="text"] {
            width: 200px;
        }

        input[type="submit"] {
            padding: 5px 10px;
            background-color: #4CAF50;
            color: white;
            border: none;
            cursor: pointer;
        }
    </style>
</head>
<body>
    <h2>商品查询</h2>
    <form action="ProductQueryServlet" method="post">
        <label for="query">查询关键字:</label>
        <input type="text" id="query" name="query" required>
        <input type="submit" value="查询">
    </form>
    <hr>
    <h3>查询结果</h3>
    <table>
        <tr>
            <th>商品ID</th>
            <th>商品名称</th>
            <th>价格</th>
        </tr>
        <!-- 查询结果会通过JavaScript动态填充到这里 -->
    </table>
</body>
</html>

本示例中创建了一个简单的页面,包括一个查询表单和用于展示查询结果的表格。

4.2 JavaScript处理查询请求和响应

为了能够发送查询请求并展示查询结果,我们使用JavaScript来处理表单的提交事件。在页面底部的 </body> 标签之前添加以下代码:

<script>
    // 在页面加载完毕后,为表单添加提交事件处理程序
    document.addEventListener('DOMContentLoaded', function() {
        document.querySelector('form').addEventListener('submit', function(e) {
            e.preventDefault(); // 防止表单自动提交

            // 获取查询关键字
            let query = document.getElementById('query').value;

            // 构建查询URL
            let url = 'ProductQueryServlet?query=' + encodeURIComponent(query);

            // 发送异步GET请求
            let xhr = new XMLHttpRequest();
            xhr.open('GET', url, true);
            xhr.onreadystatechange = function() {
                if (xhr.readyState === 4 && xhr.status === 200) {
                    // 处理响应,将查询结果填充到表格中
                    let response = JSON.parse(xhr.responseText);
                    let table = document.querySelector('table');
                    table.innerHTML = `
                        <tr>
                            <th>商品ID</th>
                            <th>商品名称</th>
                            <th>价格</th>
                        </tr>`;

                    response.forEach(function(product) {
                        let row = table.insertRow(-1);
                        row.insertCell(0).textContent = product.productId;
                        row.insertCell(1).textContent = product.productName;
                        row.insertCell(2).textContent = product.price;
                    });
                }
            };
            xhr.send();
        });
    });
</script>

此段JavaScript代码负责监听表单的提交事件,并通过异步GET请求向 ProductQueryServlet 发送查询参数。查询结果以JSON格式返回,并动态填充到表格中。

到目前为止,我们已经完成了前端列表展示页面的编写。接下来我们将在Servlet中处理查询请求并返回合适的结果。

第五步:测试和部署

在测试和部署商品查询功能之前,请确保已经完成以下准备工作:

  1. 已经搭建好开发环境,包括安装好 JDK、Tomcat 和 MySQL 数据库。

  2. 已经创建好数据库表,并插入了测试数据。

现在,我们开始测试和部署商品查询功能。

1. 编写测试脚本

首先,让我们编写一个简单的测试脚本 ProductQueryTest.java,用于自动化测试商品查询功能。

import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.net.HttpURLConnection;
import java.net.URL;

public class ProductQueryTest {
    public static void main(String[] args) {
        try {
            // 创建连接
            URL url = new URL("http://localhost:8080/bookstore/productQuery?keyword=java");
            HttpURLConnection connection = (HttpURLConnection) url.openConnection();

            // 设置请求方法
            connection.setRequestMethod("GET");

            // 发起请求
            int responseCode = connection.getResponseCode();

            // 读取响应结果
            BufferedReader reader = new BufferedReader(new InputStreamReader(connection.getInputStream()));
            String line;
            StringBuilder response = new StringBuilder();
            while ((line = reader.readLine()) != null) {
                response.append(line);
            }
            reader.close();

            // 打印响应结果
            System.out.println("Response Code: " + responseCode);
            System.out.println("Response Body: " + response.toString());
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

上述代码创建了一个 HTTP 连接,发送 GET 请求到 http://localhost:8080/bookstore/productQuery?keyword=java,其中 keyword 参数指定了查询关键字。

2. 运行测试脚本

接下来,我们需要运行测试脚本以验证商品查询功能的正确性。请按照以下步骤进行:

  1. ProductQueryTest.java 编译为 ProductQueryTest.class

  2. 启动 Tomcat 服务器。

  3. 在命令行中执行以下命令运行测试脚本:

java ProductQueryTest

注意,确保已经进入到包含 ProductQueryTest.class 的目录中。

3. 检查测试结果

运行测试脚本后,将会得到查询结果。请检查以下几个方面来验证查询结果的正确性:

  1. 响应代码 Response Code 是否为 200,表示请求成功。

  2. 响应体 Response Body 是否包含预期的商品信息,可以与预期结果进行比对。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Servlet+JDBC实战开发书店项目讲解第三篇:商品查询实现 的相关文章

  • Dynamic Web project,Jsp可正常访问,servlet出现404,刷新出现Http500,解决方式

    新手建立首个Dynamic Web project Jsp可正常访问 servlet出现404 刷新出现Http500 解决方式如下 Tips 关于配置servlet到web xml Servlet class 为pakagename se
  • Cookie:使用Cookie实现记住用户的账号和密码

    目录 练习一 java web jsp 中使用cookie记住用户的账号和密码 练习二 java web jsp servert 中使用cookie记住用户的账号和密码 进阶例题 java web中使用cookie记住用户的账号和密码 练习
  • Interceptor拦截器的使用

    1 创建配置类 Configuration public class WebConfig implements WebMvcConfigurer Autowired private AuthInterceptor authIntercept
  • 02-JavaWeb之Servlet及相关知识点

    一 Servlet 简介 Java Servlet 是运行在 Web 服务器 tomcat 或应用服务器上的程序 它可以接收来自 Web 浏览器或其他 HTTP 客户端的请求 并进行结果的响应 使用 Servlet 可以收集来自网页表单的用
  • C++异常

    全文目录 概念 异常的抛出 在函数调用链中异常栈展开匹配原则 异常的重新抛出 异常安全 异常规范 C 标准库的异常体系 异常的优缺点 概念 C语言处理异常的方式 终止程序 返回错误码 很多系统的库函数就是使用这中方式 C 异常 异常是一种处
  • [学习笔记] EL 使用EL表达式获得作用域属性

    采用EL表达式 对于属性的访问的隐含访问顺序是 pageContext httpServletRequest HttpSession ServletContext 通过以下实例 来说明 servlet scopeVar java impor
  • 芯片细分领域

  • 如何创建HttpServletRequest对象

    我们常用的就是在Controller层的接口入参时定义 这样我们就能直接用了 如下图 但是某些情况 我们需要传递这个request 到各种工具类中 传递这个request 相对要麻烦一些 我们可以不用传递 在需要用到request的地方 通
  • 淘宝官方订单API接口,获取售出的商品订单列表(爬虫数据)

    淘宝 天猫获取售出的商品订单列表 API 返回值说明 seller order list 获取售出的商品订单列表 公共参数 名称 类型 必须 描述 key String 是 调用key 必须以GET方式拼接在URL中 获取Key和secre
  • Codeup(云效)手把手教部署SpringCloud项目到私有主机

    博主介绍 小黄鸭技术 擅长领域 Java 实用工具 运维 系列专栏 开发工具 Java之路 八股文之路 如果文章写作时有错误的地方 请各位大佬指正 一起进步 欢迎大家点赞 收藏 评论 支持博主 开通云效 上传代码仓库 配置SSH公钥或者是H
  • 什么是servlet?servlet有什么用?

    servlet概述 什么是servlet servlet有什么用 servlet是java编写的服务器端的程序 运行在web服务器中 作用 接收用户端发来的请求 调用其他java程序来处理请求 将处理结果 返回到服务器中 servlet的生
  • Servlet接口实现类

    JavaWeb 03 Servlet 02 Servlet接口实现类 1 什么是Servlet接口 有什么用 Servlet接口来自于Servlet规范中的一个接口 这个接口存在于Http服务器所提供的jar包中 Servlet接口的具体位
  • JavaWeb05(删除&增加&修改功能实现&连接数据库)

    目录 一 实现删除功能 1 1 url如何传参 xx do 参数 参数值 参数名 参数值 1 2 servlet如何拿对应值 根据参数名拿到对应的参数值 String str req getParameter 参数名 1 3 如何询问 nc
  • Web前端开发概述

    Web World Wide Web 全球广域网 是指一种基于互联网的信息系统 通过超文本链接将全球各地的文档 图像 视频等资源相互关联起来 并通过Web浏览器进行交互浏览和访问 Web的发展使得人们可以方便地获取和共享各种类型的信息 成为
  • 解决request.getServletContext()方法报红问题

    getServletContext 方法是Servlet3 0添加的 所以需要引入3 0以上的jar包
  • 纯java实现相片转素描

    1 实例演示图片转素描效果 首先我们来看一下具体的效果 在项目中添加依赖
  • java文件上传

    简介 java文件上传 1 Commons FileUpload简介 1 Commons FileUpload组件 Commons是Apache开放源代码组织的一个Java子项目 其中的FileUpload是用来处理HTTP文件上传的子项目
  • this调用本类的其他构造器

    Student类 package Java project 1 public class Student private String name private String schoolName public Student public
  • IDEA找不到程序包 和 request.getServletContext()报错Cannot resolve method ‘getServletContext()的解决方法

    重新装了idea和down了项目却一直报错 在调用request getServletContext 的方法时一直报Cannot resolve method getServletContext 的错误 网上查了好多方法 大多数都是在说是s
  • JavaWeb——第五章 Servlet

    第五章 Servlet 一 Servlet简介 1 1 动态资源和静态资源 1 2 Servlet简介 二 Servlet开发流程 2 1 目标 2 2 开发过程 三 Servlet注解方式配置

随机推荐

  • 【PCIe】3: PCIe BDF(Bus,Device,Function)

    目录 1 概述 2 BUS 总线号 3 Device 设备号 4 Function 功能号 1 概述 PCIe总线中的每一个功能都有一个唯一的标识符与之对应 这个标识符就是BDF Bus Device Function
  • Knife4j 基础(OpenAPI2)

    1 Knife4j OpenApi2 入门示例 Knife4j是一个集Swagger2 和 OpenAPI3 为一体的增强解决方案 本文按照官方文档 在 SpringBoot2 7 项目中 集成 Knife4j 的 OpenApi2 版本
  • vscode中编译时当前工作目录的设置

    options cwd usr bin 在tasks json中options选项中 使用cwd项进行编译过程当前工作目录的设置 上面的代码把编译时的当前工作目录强制设置到 usr bin 如果使用该选项不设置 则工作目录为当前打开工程的文
  • go ethereum private net 在miner.start()后返回null及停止挖矿的问题

    查了好久在go ethereum社区查到一个情况相同的提问 why does miner start return null does not start in private testchain 提问者也是在miner start 后进入
  • 1、asyncio aiohttp aiofile 异步爬取图片

    1 asyncio aiohttp aiofile 异步爬取图片 前后折腾了好多天 不废话 先直接上代码 再分析 1 import aiohttp 2 import asyncio 3 import aiofiles 4 5 header
  • Surround the Trees

    http acm zju edu cn onlinejudge showProblem do problemId 453 There are a lot of trees in an area A peasant wants to buy
  • Linux下的grub2引导修复

    目录 引导故障分析处理 1 修复grub2引导故障 2 修复grub2 误删掉 boot grub2 3 修复grub2 引导破坏故障 4 修复 boot 下所有文件被删除故障 引导故障分析处理 1 修复grub2引导故障 故障原因 gru
  • 第五章-数字水印-2-原理及实现

    数字水印原理 根据之前图像获取位平面的操作可知 最低位位平面对整体图像的影响最小 因此数字水印的原理为在图像的最低有效位上嵌入隐藏信息 即在图像的最低位替换为数字水印位平面 完成数字的嵌入操作 对已嵌入数字水印的图片提取最低位位平面 即可得
  • 计算机数值分析课学后感,计算方法课程总结 心得体会

    计算方法课程总结 心得体会 一 课程简介 本课程是信息与计算科学 数学与应用数学本科专业必修的一门专业基础课 我们需在掌握数学分析 高等代数和常微分方程的基础知识之上 学习本课程 在实际中 数学与科学技术一向有着密切关系并相互影响 科学技术
  • 白手起家学习数据科学 ——梯度下降法之“优化步长和随机梯度下降篇”(六)

    选择正确的步长 Choosing the Right Step Size 虽然针对梯度移动的基本原理是清楚的 但是移动多少是不清楚的 的确 选择一个合适的步长是一门艺术 流行的选择包括 使用固定的步长 随时间逐步缩小步长 在每次迭代 选择最
  • ajp8009端口分析

    1 AJP是什么 最近有一个ajp的文件包含漏洞CVE 2020 1938很火 因此就研究了一下tomcat的ajp服务 复现了该漏洞 首先我们来看一下ajp是什么 ajp是tomcat的一个转发协议 通过这个协议 我们可以在自己的客户端上
  • linux入门系列9--用户管理及文件权限控制

    前面文章分享了Linux下常用命令以及Shell编程相关知识 本节继续学习Linux用户管理及文件权限控制 Linux是多用户多任务操作系统 具有很好的稳定性和安全性 既然是多用户 那就意味着多个用户可以同时使用同一个Linux操作系统 因
  • 接口自动化测试框架HttpClient-2-GetPost请求

    Get请求 1 请求Url 2 请求参数 3 请求header 4 响应结果断言 5 响应数据提取 public static void getDefault String url 创建一个可关闭的HttpClient对象 Closeabl
  • python实现逻辑回归建模进行分类预测及特征分析

    实现功能 python实现数据读取 数据清洗 数据编码 数据划分 并实现逻辑回归建模分类预测及特征分析 实现代码 导入需要的库 from warnings import simplefilter simplefilter action ig
  • Hypertable sql

    First create a new namespace called Test CREATE NAMESPACE Test and make it the current namespace USE Test Now let s crea
  • ListView 实时刷新数据时出现闪烁的问题

    在ListView所在的窗体类文件里面 比如Form1 另写一个扩展方法 代码如下 public static class DoubleBufferListView
  • 关于微信小程序中左上角返回键触发事件

    此时在详情页点击收藏按钮之后 点击页面左上角的返回事件 需要在列表页同时显示收藏标志 收藏是存在缓存里面的 此时如果列表页想要获取收藏的缓存 不能在onLoad函数中获取缓存 需要在onShow函数中获取 这样页面的图标才会同步显示
  • C语言 json parser - JSMN

    项目地址 GitHub zserge jsmn Jsmn is a world fastest JSON parser tokenizer This is the official repo replacing the old one at
  • python总结——对象

    目录 一 对象的知识 二 对象在内存的存储 一 对象的知识 1 python中 一切皆对象 每个对象有 标识 地址 类型 数据类型 值组成 2 对象的本质 一个内存块 拥有特定的值 支持特定类型的相关操作 3 对象存储在堆 变量存储在栈 变
  • Servlet+JDBC实战开发书店项目讲解第三篇:商品查询实现

    Servlet JDBC实战开发书店项目讲解第三篇 商品查询实现 本篇博客将介绍如何在Servlet JDBC实战开发书店项目中实现商品查询功能 我们将从设计数据库表结构和实体类开始 一步一步详细讲解代码实现过程 包括前端页面的设计和后端S