目标: l 掌握购物车的信息如何存储; l 掌握购物车
常用功能的实现。 主要内容: l 首先分析用户上网购物的一般过程; l 介绍采用什么样的数据结构存储购物信息; l 编写购物界面; l 完成向购物车添加物品的功能。 1、 用户上网购物的一般过程 在浏览物品的过程中如果对某件物品感兴趣,会添加到购物车(购物篮)中,随时可以 查看购物车中的信息,如果不想要某件物品的话,可以删除,或者修改某种物品的数量,或 者整个清空购物车,可以继续选择物品向购物车中添加。最后用户可以购物这些物品,经过 输入个人的送货地址信息和设定交易方式之后, 可以生成订单。 网站的管理员可以对订单进 行管理。 本实例模拟这个过程,但是进行了简化:只能在物品列表中选择物品向购物车中添加。 确定购买后,不需要设置交易方式以及付款等。实际处理过程,可以使用我们前面介绍的功 能完成。 2、 购物车信息组织 因为在用户访问网站的整个过程中都可以访问购物车信息, 所以购物车对象应该存放在 session 中。 因为用户购买的物品的种类和数量都不确定,所以需要使用一个合适的数据结构存储, 我们选择 ArrayList。 每一种物品都涉及数量,需要进行封装,把物品和数量封装成购物项,使用 Item,每 个 Item 对应一种物品以及该种物品的数量。 需要编写物品类表示物品的基本信息。 参考代码如下: 2.1 物品类 该类中包含两个与分页显示相关的方法。其中用到的 DBBean 是前面介绍的。 package javabean; import java.util.ArrayList; import java.sql.*; public class Goods { private String goodsid; private String goodsname; private float price; // 物品编号 public void setGoodsid(String goodsid) { this.goodsid = goodsid; } public String getGoodsid() { return goodsid;
} // 物品名称 public void setGoodsname(String goodsname) { this.goodsname = goodsname; } public String getGoodsname() { return goodsname; } // 物品价格 public void setPrice(float price) { this.price = price; } public float getPrice() { return price; } public ArrayList getGoodsByPage(int pageNo) { int number = 10; // 每一页显示的记录数 int begin = (pageNo * number) - 9; int end = pageNo * number; int index = 1; DBBean db = new DBBean(); // 要返回的结果对象 ArrayList goods = new ArrayList(); String sql = "select * from goods"; ResultSet rs; try{ rs = db.executeQuery(sql,null); while (rs.next()) { // 在 begin 之前的记录是不显示的 if (index < begin) { index++; continue; } // 在 end 之后的记录也不显示 if (index > end) break; index++;
String goodsid = rs.getString(1); String goodsname = rs.getString(2); float price = rs.getFloat(3); Goods g = new Goods(); g.setGoodsid(goodsid); g.setGoodsname(goodsname); g.setPrice(price); goods.ad
d(g); } }catch(Exception e){ e.printStackTrace(); }finally{ db.close(); } return goods; } public Goods findGoodsById(String goodsid) { try { // 编写查询数据库信息的 SQL 语句 String
sql = "select * from goods where goodsid=?"; DBBean db = new DBBean(); ArrayList params = new ArrayList(); params.add(goodsid); ResultSet rs = db.executeQuery(sql,params); if(rs.next()) { //String goodsid =rs.getString(1); String goodsname = rs.getString(2); float price = rs.getFloat(3); Goods temp = new Goods(); temp.setGoodsid(goodsid); temp.setGoodsname(goodsname); temp.setPrice(price); db.close(); return temp; }else{ return null; } } catch (Exception e) {
System.out.println(e.toString()); return null; } } public int getPageCount() { try { // 编写
查询数据库信息的 SQL 语句 String sql = "select count(*) from goods"; D