0%

JavaWeb书城项目(八)———购物车模块

整个项目源代码可以到我的github上下载。上一部分,我们对用户功能进行了完善,这一部分我们完成购物车模块,主要包括添加商品到购物车,删除商品,清空购物车。

购物车模块分析

购物车模块分析
我们使用Session版本实现购物车,这样就不需要 Dao 层和 Service 层了。


购物车模型编写

  1. 创建CartItem类定义购物车中的商品项,其有以下属性
1
2
3
4
5
private Integer id; //编号
private String name; //名称
private Integer count; //数量
private BigDecimal price; //单价
private BigDecimal totalprice; //总价
  1. 创建Cart类定义购物车
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
package com.atguigu.pojo;

import java.math.BigDecimal;
import java.util.LinkedHashMap;
import java.util.Map;

/**
* 购物车对象
*/
public class Cart {

/**
* key 是商品编号
* value 是商品信息
*/
private Map<Integer, CartItem> items = new LinkedHashMap<Integer, CartItem>();

public void addItem(CartItem cartItem) {
// 先查看购物车中是否已经添加过此商品,如果已添加,则数量累加,总金额更新,如果没有添加过,直接放到集合中即可
CartItem item = items.get(cartItem.getId());

if( item == null )
{
// 之前没添加过此商品
items.put(cartItem.getId(), cartItem);
} else {
// 已经添加过的情况
item.setCount( item.getCount() + 1 ); //数量增加
item.setTotalprice( item.getPrice().multiply(new BigDecimal( item.getCount() ))); // 更新总金额
}
}

/**
* 删除商品项
* @param id
*/
public void deleteItem(Integer id) {
items.remove(id);
}

/**
* 清空购物车
*/
public void clear() {
items.clear();
}

/**
* 修改商品数量
* @param id
* @param count
*/
public void updateCount(Integer id, Integer count) {
// 先查看购物车是否有此商品。如果有,修改商品数量,更新总金额
CartItem cartItem = items.get(id);
if (cartItem != null) {
cartItem.setCount(count); // 修改商品数量
cartItem.setTotalprice( cartItem.getPrice().multiply(new BigDecimal( cartItem.getCount() )));
}
}

/**
* 获得总数量
* @return
*/
public Integer getTotalCount() {
Integer totalCount = 0;

for (Map.Entry<Integer,CartItem>entry : items.entrySet()) {
totalCount += entry.getValue().getCount();
}

return totalCount;
}

public BigDecimal getTotalPrice() {
BigDecimal totalPrice = new BigDecimal(0);

for (Map.Entry<Integer,CartItem>entry : items.entrySet()) {
totalPrice = totalPrice.add(entry.getValue().getTotalprice());
}

return totalPrice;
}

public Map<Integer, CartItem> getItems() {
return items;
}

public void setItems(Map<Integer, CartItem> items) {
this.items = items;
}

@Override
public String toString() {
return "Cart{" +
"totalCount=" + getTotalCount() +
", totalPrice=" + getTotalPrice() +
", items=" + items +
'}';
}
}

  1. 购物车的测试,创建测试类CartTest
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
package com.atguigu.test;

import com.atguigu.pojo.Cart;
import com.atguigu.pojo.CartItem;
import org.junit.Test;

import java.math.BigDecimal;

import static org.junit.Assert.*;

public class CartTest {

@Test
public void addItem() {
Cart cart = new Cart();
cart.addItem(new CartItem(1, "java从入门到精通", 1, new BigDecimal(1000),new BigDecimal(1000)));
cart.addItem(new CartItem(1, "java从入门到精通", 1, new BigDecimal(1000),new BigDecimal(1000)));
cart.addItem(new CartItem(2, "数据结构与算法", 1, new BigDecimal(100),new BigDecimal(100)));
System.out.println(cart);
}

@Test
public void deleteItem() {
Cart cart = new Cart();
cart.addItem(new CartItem(1, "java从入门到精通", 1, new BigDecimal(1000),new BigDecimal(1000)));
cart.addItem(new CartItem(1, "java从入门到精通", 1, new BigDecimal(1000),new BigDecimal(1000)));
cart.addItem(new CartItem(2, "数据结构与算法", 1, new BigDecimal(100),new BigDecimal(100)));
cart.deleteItem(1);
System.out.println(cart);
}

@Test
public void clear() {
Cart cart = new Cart();
cart.addItem(new CartItem(1, "java从入门到精通", 1, new BigDecimal(1000),new BigDecimal(1000)));
cart.addItem(new CartItem(1, "java从入门到精通", 1, new BigDecimal(1000),new BigDecimal(1000)));
cart.addItem(new CartItem(2, "数据结构与算法", 1, new BigDecimal(100),new BigDecimal(100)));
cart.deleteItem(1);
cart.clear();
System.out.println(cart);
}

@Test
public void updateCount() {
Cart cart = new Cart();
cart.addItem(new CartItem(1, "java从入门到精通", 1, new BigDecimal(1000),new BigDecimal(1000)));
cart.addItem(new CartItem(1, "java从入门到精通", 1, new BigDecimal(1000),new BigDecimal(1000)));
cart.addItem(new CartItem(2, "数据结构与算法", 1, new BigDecimal(100),new BigDecimal(100)));
cart.deleteItem(1);
cart.clear();
cart.addItem(new CartItem(1, "java从入门到精通", 1, new BigDecimal(1000),new BigDecimal(1000)));
cart.updateCount(1, 10);
System.out.println(cart);
}
}

加入购物车功能的实现

  1. CartServlet程序中的代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
protected void addItem(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
// 获取请求的参数 商品编号
int id = WebUtils.parseInt(req.getParameter("id"), 0);
// 调用 bookService.queryBookById(id):Book 得到图书的信息
Book book = bookService.queryBookById(id);
// 把图书信息,转换为CartItem商品项
CartItem cartItem = new CartItem(book.getId(), book.getName(), 1, book.getPrice(), book.getPrice());
// 调用Cart.addItem(CartItem);添加商品项
Cart cart = (Cart) req.getSession().getAttribute("cart");
if (cart == null) {
cart = new Cart();
req.getSession().setAttribute("cart", cart);
}
cart.addItem(cartItem);

System.out.println(cart);
System.out.println("请求头Referer的值:" + req.getHeader("Referer"));

// 重定向回原来商品所在的地址页面
resp.sendRedirect(req.getHeader("Referer"));
}
  1. index.jsp页面js的代码
    修改index.jsp
  1. 图解说明,如何跳回添加商品的页面
    跳回添加商品的页面

购物车的展示

修改 cart.jsp
修改cart,jsp(一)
修改cart.jsp(二)


删除购物车商品项

  1. CartServlet增加deleteItem方法
1
2
3
4
5
6
7
8
9
10
11
12
protected void deleteItem(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
// 获取商品编号
int id = WebUtils.parseInt(req.getParameter("id"), 0);
// 获取购物车对象
Cart cart = (Cart) req.getSession().getAttribute("cart");

if (cart != null) {
// 删除购物车商品项
cart.deleteItem(id);
// 重定向回原来购物车展示页面
resp.sendRedirect(req.getHeader("Referer"));
}
  1. 修改cart.jsp,添加删除的请求地址,并增加确认删除的提示。

修改cart.jsp


清空购物车

CartServlet增加clear方法

1
2
3
4
5
6
7
8
9
10
protected void clear(HttpServletRequest req, HttpServletResponse resp) throws ServletException,IOException{
// 1 获取购物车对象
Cart cart = (Cart) req.getSession().getAttribute("cart");
if (cart != null) {
// 清空购物车
cart.clear();
// 重定向回原来购物车的展示页面
resp.sendRedirect(req.getHeader("Referer"));
}
}

cart.jsp页面的内容,给购物车添加请求地址,和添加id属性,以及清空确认提示操作
修改cart.jsp


修改购物车商品的数量

  1. CartServlet添加updateCount方法
1
2
3
4
5
6
7
8
9
10
11
12
13
14
protected void updateCount(HttpServletRequest req, HttpServletResponse resp) throws ServletException,IOException{
// 获取请求的参数 商品编号,商品数量
int id = WebUtils.parseInt(req.getParameter("id"), 0);
int count = WebUtils.parseInt(req.getParameter("count"), 1);
// 获取Cart购物车对象
Cart cart = (Cart) req.getSession().getAttribute("cart");

if (cart != null) {
// 修改商品数量
cart.updateCount(id, count);
// 重定向回原来购物车展示页面
resp.sendRedirect(req.getHeader("Referer"));
}
}
  1. 修改 cart.jsp
    修改cart.jsp(一)
    修改cart.jsp(二)

首页购物车数据回显

  1. 在添加商品到购物车的时候,保存最后一个添加的商品名称。
    修改CartServlet的addItem方法
  2. index.jsp页面中输出购物车信息
    修改index.jsp
-------------本文结束感谢您的阅读-------------