电子商城加入购物车的设计流程
1.判断用户是否登录,如果用户登录采用Db存储商品(即采用数据库的方式存购物车中的商品),如果是用户未登录(即采用Cookie的方式存购物车中的商品,并且采用加密方式)
2.用户在点击购买按钮的时候,有可能是买的是单品,也有可能买的是组合套餐。从而得到点击按钮传过来的参数要么是商品的id,要么就是组合套餐的id号,同时带有商品数量。
3.对于单品来说,先判断商品此时是否处于促销时间,所以通过id首先得判断是否是促销产品,更新商品价格,然后在判断是否是限时折扣,再次更新商品价格,最后再检查库存是不是为空,购买的数量是否大于库存。对于一些虚拟产品、如F码、预售产品最好不要加入在购物车中(因为这些要么是可以直接发货,要么是需要过一段时间才能发货,对于这类产品建议直接购买,禁止加入购物车中)。
4.对于组合套餐来说,需要判断此时商品是否在组合套装中,在判断组合套餐中的每个商品是否有库存,计算组合套餐的总价格,加入购物车的时候只放组合套餐的一个商品在购物车中,同时把组合套餐id放进去,方便以后再购物车页面把组合套餐中的其他商品查询出来。
实例:
/** * 添加购物车 */ public function add() { $model_goods = M('goods'); $logic_buy = D('buy','Logic'); if (is_numeric($_GET['goods_id'])) { //商品加入购物车(默认) $goods_id = intval($_GET['goods_id']); //商品id $num= intval($_GET['num']); //商品数量 if ($goods_id <= 0) return ; //通过id获取商品的基本信息,如名称,价格,属性等(每个商城的数据库大概都是差不多的) $goods_info = $model_goods->getGoodsInfoById($goods_id); //抢购,这里就是对于如果商品处于抢购活动中,更新商品的价格,这里用的是传指针的方式,所以没有返回变量 $logic_buy->getGroupbuyInfo($goods_info); //限时折扣,对于限时折扣活动,也是更新商品的价格 $logic_buy->getXianshiInfo($goods_info,$quantity); //这里就检查库存是不是充足,有没有超拍,是不是虚拟商品或者预售商品 $this->_check_goods($goods_info,$num); } elseif (is_numeric($_GET['bid'])) {//这里传入的是组合套餐的id号 //优惠套装加入购物车(单套) if (!$_SESSION['member_id']) { $this->error('请选登录');exit(); } $bid= intval($_GET['bid']); if ($bid<= 0) return ; $model_bl = M('bundling'); $bl_info = $model_bl->getBundlingInfo(array('bid'=>$bid)); //这里很简单就是通过组合套餐ID吧组合套餐的信息查出来,活动是否处于开启状态 if (empty($bl_info) || $bl_info['bl_state'] == '0') { $this->error('该优惠套装已不存在,建议您单独购买'); } //检查每个商品是否符合条件,并重新计算套装总价 $bl_goods_list = $model_bl->getBundlingGoodsList(array('bl_id'=>$bl_id)); $goods_id_array = array(); $bl_amount = 0; foreach ($bl_goods_list as $goods) { $goods_id_array[] = $goods['goods_id']; $bl_amount += $goods['bl_goods_price']; } $model_goods = M('goods'); $goods_list = $model_goods->getGoodsInfoById($goods_id_array); foreach ($goods_list as $goods) { $this->_check_goods($goods,1); } //优惠套装作为一条记录插入购物车,图片取套装内的第一个商品图 $goods_info = array(); $goods_info['goods_id'] = $goods_list[0]['goods_id']; $goods_info['goods_name'] = $bl_info['bl_name']; $goods_info['goods_price'] = $bl_amount; $goods_info['goods_num'] = 1; $goods_info['goods_image'] = $goods_list[0]['goods_image']; $goods_info['store_name'] = $bl_info['store_name']; $goods_info['bl_id'] = $bid; $num= 1; //组合套餐中的每个商品的数量都只有一个 } //已登录状态,存入数据库,未登录时,存入COOKIE if($_SESSION['member_id']) { $save_type = 'db'; $goods_info['buyer_id'] = $_SESSION['member_id']; } else { $save_type = 'cookie'; } $model_cart = M('cart'); $insert = $model_cart->addCart($goods_info,$save_type,$num); if ($insert) { //购物车商品种数记入cookie setNcCookie('cart_goods_num',$model_cart->cart_goods_num,2*3600); $data = array('state'=>'true', 'num' => $model_cart->cart_goods_num, 'amount' => ncPriceFormat($model_cart->cart_all_price)); } else { $data = array('state'=>'false'); } exit(json_encode($data)); } /** * 检查商品是否符合加入购物车条件 * @param unknown $goods * @param number $quantity */ private function _check_goods($goods_info, $num) { if(empty($num)) { exit(json_encode(array('msg'=>'商品数量错误'))); } if(empty($goods_info)) { exit(json_encode(array('msg'=>'商品不存在'))); } if(intval($goods_info['goods_storage']) < 1) { exit(json_encode(array('msg'=>'商品库存不足'))); } if(intval($goods_info['goods_storage']) < $num) { exit(json_encode(array('msg'=>'购买数量超过库存'))); } if ($goods_info['is_virtual'] || $goods_info['is_fcode'] || $goods_info['is_presell']) { exit(json_encode(array('msg'=>'该商品不允许加入购物车,请直接购买','UTF-8'))); } }
在function.php中加入两个函数
/** * 价格格式化 * * @param int $price * @return string $price_format */ function ncPriceFormat($price) { $price_format = number_format($price,2,'.',''); return $price_format; } /** * 设置cookie * 这个加密方式是我上一篇文章里面写了的 * @param string $name cookie 的名称 * @param string $value cookie 的值 * @param int $expire cookie 有效周期 * @param string $path cookie 的服务器路径 默认为 / * @param string $domain cookie 的域名 * @param string $secure 是否通过安全的 HTTPS 连接来传输 cookie,默认为false */ function setNcCookie($name, $value, $expire='3600', $path='', $domain='', $secure=false){ if (empty($path)) $path = '/'; if (empty($domain)) $domain = SUBDOMAIN_SUFFIX ? SUBDOMAIN_SUFFIX : ''; $name = defined('COOKIE_PRE') ? COOKIE_PRE.$name : strtoupper(substr(md5(MD5_KEY),0,4)).'_'.$name; $expire = intval($expire)?intval($expire):(intval(SESSION_EXPIRE)?intval(SESSION_EXPIRE):3600); $result = setcookie($name, $value, time()+$expire, $path, $domain, $secure); $_COOKIE[$name] = $value; }