【JAVAWEB学习笔记】网上商城实战3:购物模块和订单模块
今日任务
- 完成购物模块的功能
- 完成订单模块的功能
1.1 购物模块:
1.1.1 功能演示:
商品详情:

购物车模块:

1.1.2 代码实现:
1.在商品详情的页面中点击【加入购物车】链及.
2.提交到Servlet中:
* 提交购买的商品的数量.
* 提交购买的商品的ID.
3.将购物的信息存入到session中.
* 将购物车的信息存入到session中.
* 购物项对象的封装(购物车中的每个购买商品的信息)
* 商品的对象:
* 数量
* 小计
* 购物车对象的封装(购买所有商品的信息)
* 购物项的集合
* 总计
4.在页面中将购物车的信息获得到.
* 在页面中显示出来.
【购物项的实体的封装:CartItem】
public class CartItem {
private Product product;// 购买的商品的信息
private int count; // 购买的数量
private double subtotal; // 购买商品的小计
public Product getProduct() {
return product;
}
public void setProduct(Product product) {
this.product = product;
}
public int getCount() {
return count;
}
public void setCount(int count) {
this.count = count;
}
public double getSubtotal() {
return count * product.getShop_price();
}
/*public void setSubtotal(double subtotal) {
this.subtotal = subtotal;
}*/
}
【购物车的实体:Cart】
public class Cart {
// 定义一个购物项的集合的属性:集合采用Map集合,因为移除购物项的时候方便.使用商品的id作为Map的key
// 使用购物项作为Map的value.
private Map<String,CartItem> map = new LinkedHashMap<String,CartItem>();
// 定义购物车中的总计:
private double total;
public Map<String, CartItem> getMap() {
return map;
}
public double getTotal() {
return total;
}
// 方法:将购物项添加到购物车
public void addCart(CartItem cartItem){
// 判断购物车中是否已经存在该购物项.
String id = cartItem.getProduct().getPid();
if(map.containsKey(id)){
// 如果已经存在:在原来的数量的基础上+新买的数量. 总计发生变化.
// 获得购物车中的原来购物项的信息
CartItem _cartItem = map.get(id);
_cartItem.setCount(_cartItem.getCount()+cartItem.getCount());
}else{
// 如果不存在:在集合中添加一个新的购物项. 总计发生变化.
map.put(id, cartItem);
}
total += cartItem.getSubtotal();
}
// 方法:从购物车中移除购物项
public void removeCart(String id){
// 从map中移除选中的元素.
// CartItem cartItem = map.get(id);
CartItem cartItem = map.remove(id);
// 将总计 - 移除购物项的小计
total -= cartItem.getSubtotal();
}
// 方法:清空购物车
public void clearCart(){ //
// 将map集合清空.
map.clear();
// 将总结设置为0.
total = 0;
}
}
【在购物详情页面点击加入购物车的链接】
public String addCart(HttpServletRequest req,HttpServletResponse resp){
// 接收参数:
String pid = req.getParameter("pid");
int count = Integer.parseInt(req.getParameter("count"));
try {
// 封装购物项:
CartItem cartItem = new CartItem();
// 商品对象:通过商品ID查询商品.
ProductService productService = (ProductService) BeanFactory.getBean("productService");
Product product = productService.findById(pid);
cartItem.setProduct(product);
cartItem.setCount(count);
// 调用购物车中的添加到购物车的方法:
// Cart cart = new Cart();
Cart cart = getCart(req);
cart.addCart(cartItem);
resp.sendRedirect(req.getContextPath()+"/jsp/cart.jsp");
} catch (Exception e) {
e.printStackTrace();
throw new RuntimeException();
}
return null;
}
【在购物车页面点击清空购物车】
public String clearCart(HttpServletRequest req,HttpServletResponse resp){
// 获得购物车对象.
Cart cart = getCart(req);
// 调用购物车中的方法:
cart.clearCart();
try {
resp.sendRedirect(req.getContextPath()+"/jsp/cart.jsp");
} catch (Exception e) {
e.printStackTrace();
throw new RuntimeException();
}
return null;
}
【在购物车页面点击删除链接】
public String removeCart(HttpServletRequest req,HttpServletResponse resp){
try {
// 接收参数:
String pid = req.getParameter("pid");
// 获得购物车:
Cart cart = getCart(req);
cart.removeCart(pid);
// 页面跳转
resp.sendRedirect(req.getContextPath()+"/jsp/cart.jsp");
} catch (Exception e) {
e.printStackTrace();
throw new RuntimeException();
}
return null;
}
1.2 订单模块:
1.2.1 功能演示:

1.2.2 代码实现:
1.2.2.1 创建表和实体:
CREATE TABLE `orders` ( `oid` varchar(32) NOT NULL, `ordertime` datetime DEFAULT NULL, `total` double DEFAULT NULL, `state` int(11) DEFAULT NULL, `address` varchar(30) DEFAULT NULL, `name` varchar(20) DEFAULT NULL, `telephone` varchar(20) DEFAULT NULL, `uid` varchar(32) DEFAULT NULL, PRIMARY KEY (`oid`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `orderitem` ( `itemid` varchar(32) NOT NULL, `count` int(11) DEFAULT NULL, `subtotal` double DEFAULT NULL, `pid` varchar(32) DEFAULT NULL, `oid` varchar(32) DEFAULT NULL, PRIMARY KEY (`itemid`), KEY `fk_0001` (`pid`), KEY `fk_0002` (`oid`), CONSTRAINT `fk_0001` FOREIGN KEY (`pid`) REFERENCES `product` (`pid`), CONSTRAINT `fk_0002` FOREIGN KEY (`oid`) REFERENCES `orders` (`oid`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
1.2.2.2 生成订单:
【在购物车的页面点击提交订单】
提交到Servlet:
* 封装订单和订单项.
* 调用业务层
* 清空购物车
* 页面跳转
【JAVAWEB学习笔记】网上商城实战3:购物模块和订单模块的更多相关文章
- 【JAVAWEB学习笔记】网上商城实战5:后台的功能模块
今日任务 完成后台的功能模块 1.1 网上商城的后台功能的实现: 1.1.1 后台的功能的需求: 1.1.1.1 分类管理: [查询所有分类] * 在左侧菜单页面中点击分类管理: * ...
- JAVAWEB贵美网上商城完整项目源码(SSH2)
JAVAWEB贵美网上商城完整项目源码(SSH2) 贵美网上商城原是北大青鸟的一个内部项目,项目采用 struts2+spring4+hibernate4+MySQL等技术实现,数据库连接池采用c3p ...
- JavaWeb学习笔记总结 目录篇
JavaWeb学习笔记一: XML解析 JavaWeb学习笔记二 Http协议和Tomcat服务器 JavaWeb学习笔记三 Servlet JavaWeb学习笔记四 request&resp ...
- javaweb学习笔记整理补课
javaweb学习笔记整理补课 * JavaWeb: * 使用Java语言开发基于互联网的项目 * 软件架构: 1. C/S: Client/Server 客户端/服务器端 * 在用户本地有一个客户端 ...
- 【JAVAWEB学习笔记】网上商城实战:环境搭建和完成用户模块
网上商城实战 今日任务 完成用户模块的功能 1.1 网上商城的实战: 1.1.1 演示网上商城的功能: 1.1.2 制作目的: 灵活运用所学知识完成商城实战. 1.1.3 ...
- 【JAVAWEB学习笔记】网上商城实战1:环境搭建和完成用户模块
今日任务 完成用户模块的功能 1.1 网上商城的实战: 1.1.1 演示网上商城的功能: 1.1.2 制作目的: 灵活运用所学知识完成商城实战. 1.1.3 数据库分析和设 ...
- Javaweb学习笔记——(二十四)——————图书商城项目
图书商城 环境搭建 1.导入原型 *用户模块 *分类模块 *图书模块 ...
- 【JAVAWEB学习笔记】06_jQuery基础
接05的学习笔记. 四.使用JQ完成省市二级联动 1.需求分析 使用jquery完成省市二级联动 2.技术分析 2.1数组的遍历操作 方式一: $(function(){ // 全选/ 全不选 $(& ...
- javaweb学习笔记(二)
一.javaweb学习是所需要的细节 1.Cookie的注意点 ① Cookie一旦创建,它的名称就不能更改,Cookie的值可以为任意值,创建后允许被修改. ② 关于Cookie中的setMaxAg ...
随机推荐
- 秒懂JS对象、构造器函数和原型对象之间的关系
学习JS的过程中,想要掌握面向对象的程序设计风格,对象模型(原型和继承)是其中的重点和难点,拜读了各类经典书籍和各位前辈的技术文章,感觉都太过高深,花费了不少时间才搞明白(个人智商是硬伤/(ㄒoㄒ)/ ...
- cookie和session的区别异同
1.用于保存页面信息:如自动登录,记住用户名 2.对于同一个网站只有一套cookie,它是以域名为单位的,一个域名就是一套,数量大小有限4k-10k,同时会具有过期时间 3.JS中通过document ...
- java swing组件的一些基本属性
JLabel get/setText(): 获取/设置标签的文本. get/seticon(): 获取/设置标签的图片. get/setHorizontalAlignment(): 获取/设置文本的水 ...
- STM32实战应用(一)——1602蓝牙时钟1液晶的显示测试
前言 从51到STM32F4学习这么久了,总算找到点头绪了,目前学习了GPIO,中断,定时器,看门狗的基本使用,所以想试着看看能不能做个什么东西,就是想复习一下最近学习的知识.正好上学期单片机课程设计 ...
- js日期转化(计算一周的日期)
之前做项目的时候遇到过一个日期转化的问题,一个日期控件和近一天,近七天和近一月的的联动效果.发现自己不会,后来就百度了一下解决了这个问题. 现在抽空又写了一个时间转化的案例(计算一周的日期),因为之前 ...
- Python数据处理进阶——pandas
对于python进行数据处理来说,pandas式一个不得不用的包,它比numpy很为强大.通过对<利用python进行数据分析>这本书中介绍pandas包的学习,再加以自己的理解,写下这篇 ...
- Machine Learning——Supervised Learning(机器学习之监督学习)
监督学习是指:利用一组已知类别的样本调整分类器的参数,使其达到所要求性能的过程. 我们来看一个例子:预测房价(注:本文例子取自业界大牛吴恩达老师的机器学习课程) 如下图所示:横轴表示房子的面积,单位是 ...
- 关于使用mybatis的几点总结
mybatis的几点总结 1.关于resultType和resultMap的使用 查询结果集统一采用resultType,不要采用resultMap,因为resultMap需要写许多的表字段和实体类的 ...
- Oracle数据库时间类型悬疑案
这次遇到的问题小Alan其实一年半前做证券行业项目就已经遇到过,但是一直没有去思考是什么原因导致的这样的悬疑案,悬疑案是什么呢?其实很简单,我想有不少童鞋都有用到Oracle数据库,情形是这样子的,这 ...
- webService 下得 拦截
当我们 对webservice 接口的 拦截 更具权限 来 判断 是否可以调用 一下是我的 一个demo 首先 我们写一个 拦截类 import javax.xml.soap.SOAPExcept ...