學習筆記——書城項目第六階段之去結賬功能的準備工作、去結賬功能的實現

来源:https://www.cnblogs.com/isDaHua/archive/2023/01/07/17032169.html
-Advertisement-
Play Games

2023-01-07 一、去結賬功能的準備工作 (1)需要完成的要求:將購物車內所有圖書都結賬。 (2)分析: ①結賬會生成訂單 訂單中的信息包含主鍵(唯一標識,使用自增)、訂單號(後臺生成一個唯一標識對於訂單)、訂單時間(點 擊去結賬時的系統時間)、訂單金額(即購物車的總金額)、訂單數量(即購物車 ...


2023-01-07

一、去結賬功能的準備工作

(1)需要完成的要求:將購物車內所有圖書都結賬。

(2)分析:

①結賬會生成訂單

訂單中的信息包含主鍵(唯一標識,使用自增)、訂單號(後臺生成一個唯一標識對於訂單)、訂單時間(點 擊去結賬時的系統時間)、訂單金額(即購物車的總金額)、訂單數量(即購物車的總數量)、訂單狀態(包含等待發貨、已發貨、未發貨、確認收貨)、用戶id(用於標識用戶,即記錄當前訂單屬於哪個用戶)

②訂單項包含的內容(之前的購物項對應現在的訂單項)

主鍵、書的圖片、書名、價格、數量、金額、訂單id(當前訂單項關聯的訂單表的主鍵)

(3)結論:訂單和訂單項的數據應該存儲在資料庫內

(4)創建表格(要存儲在資料庫內,所以要在資料庫中創建一個存儲訂單項的表格,變數的設置使用分析到的訂單內容進行設置)

在資料庫中創建表格的語句

CREATE TABLE t_order(
                order_id INT PRIMARY KEY AUTO_INCREMENT,
                order_sequence VARCHAR(200),
                create_time VARCHAR(100),
                total_count INT,
                total_amount DOUBLE,
                order_status INT,
                user_id INT
            );

打開資料庫,將語句放在這裡

 

 

 之後選中語句,點擊運行,最後進行刷新

 

 

 說明:訂單的狀態中:已支付,待發貨(使用0);已發貨(使用1);確認收貨(使用2)

(5)訂單項中的表格

步驟同(4),創建表格的sql語句為

CREATE TABLE t_order_item(
                item_id INT PRIMARY KEY AUTO_INCREMENT,
                book_name VARCHAR(20),
                price DOUBLE,
                img_path VARCHAR(50),
                item_count INT,
                item_amount DOUBLE,
                order_id VARCHAR(20)
            );

(6)在src中的com.hh.bean文件夾下創建“OrderItem”類、“Order”類

OrderItem類包含的欄位:

public class OrderItem {
    private Integer itemId;
    private String bookName;
    private Double price;
    private String imgPath;
    private Integer itemCount;
    private Double itemAmount;
    private Integer orderId;
}

Order類包含的欄位:

public class Order {
    private Integer orderId;
    private String orderSequence;
    private String createTime;
    private Integer totalCount;
    private Double totalAmount;
    private Integer orderStatus;
    private Integer userId;
}

之後在兩個類中使用快捷鍵“Insert+Alt”,創建有參、無參構造器、getter、setter、tostring方法

 

 

 二、去結賬功能的實現

(1)在src文件夾下“com.hh.servlet.model”中創建一個“Servlet”,命名為“OrderServlet”.

 

 

 

 

 

 在“OrderServlet”中的註解中設置訪問路徑

@WebServlet(name = "OrderServlet",value = "/order")

(2)找到“去結賬”的位置,發出請求。在“cart.html”中的第78行代碼,將路徑傳過去

<a class="pay" href="order?flag=createOrder">去結賬</a>

(3)在“OrderServlet”中創建“createOrder”方法

在該類中將“doPost”、“doGet”函數刪除,設置“createOrder”函數

@WebServlet(name = "OrderServlet",value = "/order")
public class OrderServlet extends HttpServlet {
    protected void createOrder(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        //處理結賬的請求
        //1.獲得請求參數(要獲得結賬相關的數據)
        //①獲得購物車信息(n個購物項,總數量,總金額)
        HttpSession session = request.getSession();
        Cart cart = (Cart)session.getAttribute("cart");
        //②獲得當前登錄人的信息(登陸之後再去結賬)
        User user = (User)session.getAttribute("user");//如果沒有登錄user則為null
        //2.調用業務層處理業務
        //3.給響應
    }
}

(4)在“src”中的“com.hh.service”中創建一個“OrderService”的介面

public interface OrderService {
    //處理創建訂單的業務
    String createOrder(Cart cart, User user); 
}

(5)在src文件夾下的“com.hh.service.impl”中創建實現類“OrderServiceImpl”

public class OrderServiceImpl implements OrderService {
    @Override
    public String createOrder(Cart cart, User user) {
        //1.創建訂單信息並保存到資料庫
        String orderSequence="hh"+System.currentTimeMillis();//訂單號
        Date date = new Date();
        //對當前系統時間進行格式化
        SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
        String format = sdf.format(date);//字元串格式的當前系統時間
        Order order = new Order(null,orderSequence,format,cart.getTotalCount(),cart.getTotalAmount(),0,user.getId());
        //調用dao層將order的數據添加到資料庫內
        //2.創建n個訂單信息並保存到資料庫
        //3.對圖書的庫存和銷量進行修改操作(暫時不考慮庫存不足的情況)
        return null;
    }
}

(6)在“src”文件夾下的“com.hh.dao”中創建一個介面“OrderDao”

public interface OrderDao {
    /**
     * 功能:添加訂單信息
     * @param order
     */
    void addOrder(Order order);

    /**
     * 功能:根據訂單編號查找訂單ID
     * @param orderSequence
     * @return
     */
    Integer findIdBySequence(String orderSequence);
}

(7)在src中的“com.hh.dao.impl”中創建“OrderDaoImpl”類

public class OrderDaoImpl extends BaseDaoImpl implements OrderDao {
    @Override
    public void addOrder(Order order) {
        String sql="insert into t_order values(null,?,?,?,?,?,?)";
        this.update(sql,order.getOrderSequence(),order.getCreateTime(),order.getTotalCount(),order.getTotalAmount(),order.getOrderStatus(),order.getUserId());
    }

    @Override
    public Integer findIdBySequence(String orderSequence) {
        String sql="select order_id from t_order where order_sequence=?";
        return (Integer)this.getValue(sql,orderSequence); 
  }
}

(8)在src文件夾下的“com.hh.dao”中,創建“OrderItemDao”的類

public interface OrderItemDao {
    /**
     * 保存訂單項信息
     * @param orderItem
     */
    void addOrderItem(OrderItem orderItem);
}

(9)在src文件夾下的“com.hh.dao.impl”中,創建實現類“OrderItemDaoImpl”

public class OrderItemDaoImpl extends BaseDaoImpl implements OrderItemDao {
    @Override
    public void addOrderItem(OrderItem orderItem) {
        String sql="insert into t_order_item values(null,?,?,?,?,?,?)";
        this.update(sql,orderItem.getBookName(),orderItem.getPrice(),orderItem.getImgPath(),orderItem.getItemCount(),orderItem.getItemAmount(),orderItem.getOrderId());
    }
}

(10)完善“OrderServiceImpl”類中的函數

public class OrderServiceImpl implements OrderService {
    private OrderDao orderDao = new OrderDaoImpl();
    private OrderItemDao orderItemDao = new OrderItemDaoImpl();
    private BookDao bookDao = new BookDaoImpl();
    @Override
    public String createOrder(Cart cart, User user) {
        //1.創建訂單信息並保存到資料庫
        String orderSequence="hh"+System.currentTimeMillis();//訂單號
        Date date = new Date();
        //對當前系統時間進行格式化
        SimpleDateFormat sdf=new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
        String format = sdf.format(date);//字元串格式的當前系統時間
        Order order=new Order(null,orderSequence,format,cart.getTotalCount(),cart.getTotalAmount(),0,user.getId());
        //調用dao層將order的數據添加到資料庫內
        orderDao.addOrder(order);
        //2.創建n個訂單信息並保存到資料庫
        //通過迴圈的方式去實現
        //訂單id是根據訂單編號去查詢
        Integer idBySequence = orderDao.findIdBySequence(orderSequence);
        Collection<CartItem> allCartItem = cart.getAllCartItem();
        for (CartItem item : allCartItem) {
            //一個item(購物項)對應一個訂單項(OrderItem)
            OrderItem orderItem = new OrderItem(null, item.getBook().getBookName(), item.getBook().getPrice(), item.getBook().getImgPath(),item.getCount(),item.getAmount(),idBySequence);
            //調用dao層將orderItemDao的數據保存到資料庫
            orderItemDao.addOrderItem(orderItem);
            //3.對圖書的庫存和銷量進行修改操作(暫時不考慮庫存不足的情況)
            //每一個訂單項的生成都隨之改變當前書的庫存和銷量
            Book book = item.getBook();
            book.setSales(book.getSales()+item.getCount());
            book.setStock(book.getSales()-item.getCount());
            bookDao.updateBook(book);//根據書的id修改其他信息
        }
        return orderSequence;//需要把訂單號返回Servlet
    }
}

(11)完善“OrderServlet”類中的函數

@WebServlet(name = "OrderServlet",value = "/order")
public class OrderServlet extends BaseServlet {
    private OrderService orderService= new OrderServiceImpl();
    protected void createOrder(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        //處理結賬的請求
        //1.獲得請求參數(要獲得結賬相關的數據)
        //①獲得購物車信息(n個購物項,總數量,總金額)
        HttpSession session = request.getSession();
        Cart cart = (Cart)session.getAttribute("cart");
        //②獲得當前登錄人的信息(登陸之後再去結賬)
        User user = (User)session.getAttribute("user");//如果沒有登錄user則為null
        //2.調用業務層處理業務
        String orderSequence = orderService.createOrder(cart, user);
        //3.給響應
        //需要將訂單號,放在請求域,轉發到網頁,通過thymeleaf渲染
        request.setAttribute("orderSequence",orderSequence);
        this.processTemplate("cart/checkout",request,response);
    }
}

(12)在“cart.html”中設置thymeleaf的命名空間設置base

<html xmlns:th="http://www.thymaleaf.org">
<base th:href="@{/}">

在“cart.html”中的第55行進行渲染訂單號

th:text="${orderSequence}

註意:刷新伺服器後,彈出的頁面一直報404,找了很長時間,最後發現是“web.xml”中的問題,“<servlet-class>”在遷移之後裡面的不是按照“com.hh.servlet.model.ToIndexPageServlet”,而是“ToIndexPageServlet”,之後將類似的問題改過之後就OK了。如果下次遇到同樣的問題報404時,先要檢查“web.xml”。

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 上一篇博客中只是瞭解一下java文件是怎麼編譯的,但是一般來說大家都是使用編程軟體來進行開發,我是使用IntelliJ IDEA進行開發的官網下載IDEA(自行安裝哈):地址:https://www.jetbrains.com/idea/download/other.html使用IDEA我使用的id ...
  • 簡介: 狀態模式,屬於行為型的設計模式。當一個對象的內在狀態發生改變時,允許改變其行為,這個對象看起來像是改變了其類。 適用場景: 控制一個對象的狀態改變過於複雜時,把狀態的判斷邏輯轉移到表示不同狀態的一系列類中。 一個對象的行為取決於它的狀態,並且在運行時刻根據狀態改變它的行為時,方便使用狀態模式 ...
  • 在安裝pip的出現異常提示: ERROR: Could not find a version that satisfies the requirement pillow (from versions: none) ERROR: No matching distribution found for p ...
  • 原創:扣釘日記(微信公眾號ID:codelogs),歡迎分享,轉載請保留出處。 簡介 最近,我們系統配置了GC耗時的監控,但配置上之後,系統會偶爾出現GC耗時大於1s的報警,排查花了一些力氣,故在這裡分享下。 發現問題 我們系統分多個環境部署,出現GC長耗時的是俄羅斯環境,其它環境沒有這個問題,這裡 ...
  • 一、基本定義 重載,顧名思義從字面上理解就是重覆裝載,打一個不恰當的比方,你可以用一個籃子裝蔬菜,也可以裝水果或者其它,使用的是同一個籃子,但是可以用籃子重覆裝載的東西不一樣。 函數重載是C++多態(靜態多態)的特征體現,它可以允許重覆使用同一個函數名(籃子)的函數,但是函數的參數列表(籃子裝的東西 ...
  • 2023-01-07 一、“我的訂單”功能 (1)找到“我的訂單”的位置 ①購物車頁面Cart.html中的第26行 ②結算完成頁面Checkout.html中的第45行 將兩個位置中超鏈接的“href”改變設置,寫為 <a href="order?flag=showOrders">我的訂單</a> ...
  • 註冊博客園 養成一個做筆記的好習慣 Markdown學習--Typora 標題--(#+空格+標題) 幾個#表示幾級標題(最多六個) 字體 粗體:** 字體 ** 斜體:* 字體 * 斜體加粗:字體(兩邊三個*) 刪除線:~~ 字體 ~~ 引用 (>空格+文字) 分割線 ( 空格) (***空格) ...
  • 1. 導入包 import pandas as pd import matplotlib.pyplot as plt import matplotlib.ticker as ticker import matplotlib.gridspec as gridspec 2. 獲得數據 file_id = ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...