電子商城加入購物車的設計流程
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;
}