Servlet+JDBC实战开发书店项目讲解第14讲:订单管理功能
欢迎阅读本系列教程的第14讲!在本篇文章中,我们将深入讲解如何在书店项目中实现订单管理功能。通过这个实例,你将学习到如何使用Servlet和JDBC来处理后台管理的订单管理操作。
1. 订单管理功能介绍
订单管理功能是书店项目中非常重要的一部分。它涉及到对订单的增删改查操作,以及订单状态的管理。在本篇文章中,我们将实现以下几个订单管理功能:
- 查看订单列表:管理员可以查看所有订单的列表,包括订单号、下单时间、订单状态等信息。
- 查看订单详情:管理员可以查看每个订单的详细信息,包括订单中的书籍、购买数量、总金额等。
- 修改订单状态:管理员可以修改订单的状态,如确认订单、取消订单等。
- 删除订单:管理员可以删除订单,同时删除订单中的书籍关联信息。
2. 创建订单管理页面
首先,我们需要创建一个订单管理页面,用于展示订单列表和订单详情。在该页面上,我们将使用表格来展示订单列表,并提供查看详情和修改状态的功能。
<!DOCTYPE html>
<html>
<head><title>订单管理</title><style>table {width: 100%;border-collapse: collapse;}th, td {padding: 8px;text-align: left;border-bottom: 1px solid #ddd;}</style>
</head>
<body><h1>订单管理</h1><table><tr><th>订单号</th><th>下单时间</th><th>订单状态</th><th>操作</th></tr><!-- 在这里使用Servlet获取订单列表并展示 --></table>
</body>
</html>
3. 实现订单管理功能的Servlet
接下来,我们将创建一个Servlet来处理订单管理功能。首先,我们需要在web.xml
文件中配置该Servlet的映射。
<servlet><servlet-name>OrderManagementServlet</servlet-name><servlet-class>com.example.OrderManagementServlet</servlet-class>
</servlet>
<servlet-mapping><servlet-name>OrderManagementServlet</servlet-name><url-pattern>/orderManagement</url-pattern>
</servlet-mapping>
然后,我们可以在OrderManagementServlet
中实现订单管理功能的相关代码。
package com.example;import java.io.IOException;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;public class OrderManagementServlet extends HttpServlet {private static final long serialVersionUID = 1L;protected void doGet(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException {List<Order> orderList = getOrderList(); // 获取订单列表request.setAttribute("orderList", orderList);request.getRequestDispatcher("orderManagement.jsp").forward(request, response);}private List<Order> getOrderList() {List<Order> orderList = new ArrayList<>();Connection conn = null;PreparedStatement stmt = null;ResultSet rs = null;try {conn = getConnection();stmt = conn.prepareStatement("SELECT * FROM orders");rs = stmt.executeQuery();while (rs.next()) {Order order = new Order();order.setOrderId(rs.getInt("order_id"));order.setOrderTime(rs.getString("order_time"));order.setStatus(rs.getString("status"));orderList.add(order);}} catch (SQLException e) {e.printStackTrace();} finally {closeResultSet(rs);closeStatement(stmt);closeConnection(conn);}return orderList;}// 其他辅助方法省略...private Connection getConnection() throws SQLException {// 获取数据库连接}private void closeResultSet(ResultSet rs) {// 关闭ResultSet}private void closeStatement(PreparedStatement stmt) {// 关闭PreparedStatement}private void closeConnection(Connection conn) {// 关闭Connection}
}
在上述代码中,我们通过getOrderList()
方法获取订单列表,并将其存储在request
对象中。然后,我们将请求转发到订单管理页面orderManagement.jsp
,并在该页面中使用EL表达式${orderList}
来展示订单列表。
4. 订单管理页面的后台处理
在订单管理页面中,我们需要添加一些后台处理的代码来实现查看订单详情和修改订单状态的功能。我们可以在订单列表中的每一行添加查看详情和修改状态的链接,并将订单号作为参数传递给后台处理。
<!-- 在订单列表中展示订单详情和修改状态的链接 -->
<tr><td>${order.orderId}</td><td>${order.orderTime}</td><td>${order.status}</td><td><a href="orderDetails?orderId=${order.orderId}">查看详情</a><a href="updateOrderStatus?orderId=${order.orderId}">修改状态</a></td>
</tr>
然后,我们需要创建两个新的Servlet来处理订单详情和修改订单状态的功能。
package com.example;import java.io.IOException;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;public class OrderDetailsServlet extends HttpServlet {private static final long serialVersionUID = 1L;protected void doGet(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException {int orderId = Integer.parseInt(request.getParameter("orderId"));Order order = getOrderDetails(orderId); // 获取订单详情request.setAttribute("order", order);request.getRequestDispatcher("orderDetails.jsp").forward(request, response);}private Order getOrderDetails(int orderId) {Order order = new Order();Connection conn = null;PreparedStatement stmt = null;ResultSet rs = null;try {conn = getConnection();stmt = conn.prepareStatement("SELECT * FROM orders WHERE order_id = ?");stmt.setInt(1, orderId);rs = stmt.executeQuery();if (rs.next()) {order.setOrderId(rs.getInt("order_id"));order.setOrderTime(rs.getString("order_time"));order.setStatus(rs.getString("status"));// 设置其他订单详情的属性...}} catch (SQLException e) {e.printStackTrace();} finally {closeResultSet(rs);closeStatement(stmt);closeConnection(conn);}return order;}// 其他辅助方法省略...
}package com.example;import java.io.IOException;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.SQLException;import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;public class UpdateOrderStatusServlet extends HttpServlet {private static final long serialVersionUID = 1L;protected void doGet(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException {int orderId = Integer.parseInt(request.getParameter("orderId"));String newStatus = request.getParameter("newStatus");updateOrderStatus(orderId, newStatus); // 修改订单状态response.sendRedirect("orderManagement"); // 重定向到订单管理页面}private void updateOrderStatus(int orderId, String newStatus) {Connection conn = null;PreparedStatement stmt = null;try {conn = getConnection();stmt = conn.prepareStatement("UPDATE orders SET status = ? WHERE order_id = ?");stmt.setString(1, newStatus);stmt.setInt(2, orderId);stmt.executeUpdate();} catch (SQLException e) {e.printStackTrace();} finally {closeStatement(stmt);closeConnection(conn);}}// 其他辅助方法省略...
}
在上述代码中,OrderDetailsServlet
通过getOrderDetails()
方法获取订单详情,并将其存储在request
对象中。然后,我们将请求转发到订单详情页面orderDetails.jsp
,并在该页面中使用EL表达式${order}
来展示订单详情。
UpdateOrderStatusServlet
通过updateOrderStatus()
方法修改订单状态,并在修改完成后重定向到订单管理页面。
5. 订单详情页面的展示
在订单详情页面中,我们可以使用EL表达式${order}
来展示订单的各个属性。
<!-- 展示订单详情 -->
<h2>订单详情</h2>
<table><tr><td>订单号:</td><td>${order.orderId}</td></tr><tr><td>下单时间:</td><td>${order.orderTime}</td></tr><tr><td>订单状态:</td><td>${order.status}</td></tr><!-- 展示其他订单详情的属性... -->
</table>
6. 修改订单状态的页面展示
在修改订单状态的页面中,我们可以使用一个表单来让用户选择新的订单状态,并将选择的状态作为参数传递给后台处理。
<!-- 修改订单状态的表单 -->
<h2>修改订单状态</h2>
<form action="updateOrderStatus" method="get"><input type="hidden" name="orderId" value="${order.orderId}"><label for="newStatus">新的订单状态:</label><select name="newStatus" id="newStatus"><option value="待付款">待付款</option><option value="待发货">待发货</option><option value="已发货">已发货</option><option value="已完成">已完成</option></select><br><input type="submit" value="提交">
</form>
在上述代码中,我们使用一个隐藏的输入字段来传递订单号,并使用一个下拉列表来让用户选择新的订单状态。用户选择的状态会在表单提交时作为参数传递给后台处理。
7. 总结
通过以上步骤,我们实现了一个简单的订单管理系统。用户可以在订单管理页面查看订单列表,并点击链接查看订单详情和修改订单状态。在订单详情页面,用户可以查看订单的详细信息。在修改订单状态的页面,用户可以选择新的订单状态并提交表单来修改订单的状态。