【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 ...
随机推荐
- GPIO的配置过程
今天看到一篇很好的博文,,看这里:http://www.cnblogs.com/crazyxu/archive/2011/10/14/2212337.html 下面总结一下,加深一下理解. 要使用GP ...
- C#Execl
using System.IO; using System.Text; namespace iLIS.Common { /// <summary> /// 生成Excel文档内容 /// ...
- 读书笔记 effective c++ Item 53 关注编译器发出的警告
许多程序员常常忽略编译器发出的警告.毕竟,如果问题很严重,它才将会变成一个error,不是么?相对来说,这个想法可能在其它语言是无害的,但是在C++中,我敢打赌编译器的实现者对于对接下来会发生什么比你 ...
- 对于Bootstrap的介绍以及如何使用
Bootstrap是HTML.CSS 和 JS 框架,用于开发响应式布局.移动设备优先的 WEB 项目. 可以自动适配任何设备,解决了响应式实现的繁琐问题,可以修改其中的各种样式,同样,其内部功能的强 ...
- [工具技巧] SecureCRT使用技巧 V1.0
本文档适用对象为需要使用secureCRT做系统或网络等调试的工程师,其必须有用过该款软件,基础功能会使用.对于那些需要修改大量设备的配置时像远程升级等等,更应该学习本文档. 1 Secu ...
- 手把手教做单点登录(SSO)系列之一:概述与示例
本系列将由浅入深的结合示例.源码以及演示视频,手把手的带大家深入最新的单点登录SSO方案选型与架构开发实战.文末附5个满足不同单点登录场景的gif动画演示(如果看不清请在图片上右键用新窗口打开),本系 ...
- 使用Spire.Doc组件利用模板导出Word文档
以前一直是用Office的组件实现Word文档导出,但是让客户在服务器安装Office,涉及到版权:而且Office安装,包括权限配置也是比较麻烦. 现在流行使用第三方组件来实现对Office的操作, ...
- (原创)性能测试中,Oracle服务器定位CPU使用率高的瓶颈(SQL)
本篇博客记录一次性能测试过程中,定位对CPU使用率高的瓶颈问题,主要定位SQL为准 一.用SQL命令定位1.首先用TOP命令监控系统资源,如果是AIX系统,就用topas,进入TOP命令的滚动刷新数据 ...
- JavaScript ,Python,java,C#,Go系列算法之【插入排序篇】
常见的内部排序算法有:插入排序.希尔排序.选择排序.冒泡排序.归并排序.快速排序.堆排序.基数排序等.用一张图概括: 插入排序 插入排序(英语:Insertion Sort)是一种简单直观的排序算法. ...
- Linux中Nginx反向代理下的tomcat集群
Nginx具有反向代理(注意和正向代码的区别)和负载均衡等特点. 这次Nginx安装在 192.168.1.108 这台linux 机器上.安装Nginx 先要装openssl库,gcc,PCRE,z ...