全球网站排行,wordpress快速审批,时网站建设公司管理,有专业做线切割配件的网站吗ServletJDBC实战开发书店项目讲解第三篇#xff1a;商品查询实现
本篇博客将介绍如何在ServletJDBC实战开发书店项目中实现商品查询功能。我们将从设计数据库表结构和实体类开始#xff0c;一步一步详细讲解代码实现过程#xff0c;包括前端页面的设计和后端Servlet代码的编…ServletJDBC实战开发书店项目讲解第三篇商品查询实现
本篇博客将介绍如何在ServletJDBC实战开发书店项目中实现商品查询功能。我们将从设计数据库表结构和实体类开始一步一步详细讲解代码实现过程包括前端页面的设计和后端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
headtitle商品查询/titlelink relstylesheet typetext/css hrefstyles.css
/head
bodyh1商品查询/h1form actionProductSearchServlet methodgetlabel forproductName商品名称/labelinput typetext idproductName namename requiredbrbrlabel forproductPrice商品价格/labelinput typenumber idproductPrice namepricebrbrinput typesubmit 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();// 将结果集转化为商品对象列表ListProduct 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
headtitle商品查询/titlestyletable {border-collapse: collapse;width: 100%;}th, td {border: 1px solid black;padding: 8px;}th {background-color: #f2f2f2;}input[typetext] {width: 200px;}input[typesubmit] {padding: 5px 10px;background-color: #4CAF50;color: white;border: none;cursor: pointer;}/style
/head
bodyh2商品查询/h2form actionProductQueryServlet methodpostlabel forquery查询关键字/labelinput typetext idquery namequery requiredinput typesubmit value查询/formhrh3查询结果/h3tabletrth商品ID/thth商品名称/thth价格/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;// 构建查询URLlet 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 trth商品ID/thth商品名称/thth价格/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中处理查询请求并返回合适的结果。
第五步测试和部署
在测试和部署商品查询功能之前请确保已经完成以下准备工作 已经搭建好开发环境包括安装好 JDK、Tomcat 和 MySQL 数据库。 已经创建好数据库表并插入了测试数据。
现在我们开始测试和部署商品查询功能。
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?keywordjava);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?keywordjava其中 keyword 参数指定了查询关键字。
2. 运行测试脚本
接下来我们需要运行测试脚本以验证商品查询功能的正确性。请按照以下步骤进行 将 ProductQueryTest.java 编译为 ProductQueryTest.class。 启动 Tomcat 服务器。 在命令行中执行以下命令运行测试脚本
java ProductQueryTest注意确保已经进入到包含 ProductQueryTest.class 的目录中。
3. 检查测试结果
运行测试脚本后将会得到查询结果。请检查以下几个方面来验证查询结果的正确性 响应代码 Response Code 是否为 200表示请求成功。 响应体 Response Body 是否包含预期的商品信息可以与预期结果进行比对。