ecshop二次開(kāi)發(fā)之購(gòu)物車分析

本文實(shí)例講述了ecshop二次開(kāi)發(fā)之購(gòu)物車分析。分享給大家供大家參考。具體分析如下:
一、保存用戶購(gòu)物車數(shù)據(jù)
ECSHOP的購(gòu)物車數(shù)據(jù),是以Session 方式存儲(chǔ)在數(shù)據(jù)庫(kù)里,并在Session結(jié)束后 ,Distroy 掉,解決方法是:
1.購(gòu)物車內(nèi)容讀取方式. 更改登陸后購(gòu)物車獲取條件 "Session 單獨(dú)方式"為 Session +用戶名 ,該修改位于Lib_order 下 function get_cart_goods();
2. 購(gòu)物車內(nèi)容記錄方式,未登陸方式依然是Session , 用戶登陸后,自動(dòng)UPdate Cart 一次,將同一UserID下購(gòu)物車內(nèi)數(shù)據(jù)不是當(dāng)前Session的Update到當(dāng)前Session , 并將當(dāng)前Session 下UserID為0的部分(未登陸情況下,Userid是0),UpdateID到當(dāng)前UserID ,該修改位于 Flow.php 下面function flow_update_cart($arr)
3.更改退出時(shí),自動(dòng)Clear Cart的部分,將Distroy 當(dāng)前Session 的內(nèi)容,更改為Distroy 當(dāng)前Session 下 User ID為0的部分。 該修改位于:Includes/cls_session.php , function destroy_session() 部分
說(shuō)明:這種情況下就是游客關(guān)閉瀏覽器后,購(gòu)物車清空, 注冊(cè)用戶購(gòu)物車永久保存, 可能會(huì)對(duì)服務(wù)器造成輕微壓力,主要取決于用戶的數(shù)量,如果數(shù)量較多數(shù)據(jù)服務(wù)器壓力較大,可以通過(guò)程序,自動(dòng)清理超過(guò)一定時(shí)間段未登陸的User Cart (或者是額外增加一個(gè)數(shù)據(jù),來(lái)標(biāo)示加入購(gòu)物車的時(shí)間,根據(jù)此時(shí)間判斷是否自
動(dòng)清理).
二、讀取購(gòu)物車數(shù)據(jù)
1.購(gòu)物車內(nèi)容讀取方式. 更改登陸后購(gòu)物車獲取條件 "Session 單獨(dú)方式"為 Session +用戶名 ,該修改位于Lib_order 下 function get_cart_goods();
具體更改代碼部分:
{
$goods_list = array();
$total = array(
'goods_price' => 0, // 本店售價(jià)合計(jì)(有格式)
'market_price' => 0, // 市場(chǎng)售價(jià)合計(jì)(有格式)
'saving' => 0, // 節(jié)省金額(有格式)
'save_rate' => 0, // 節(jié)省百分比
'goods_amount' => 0, // 本店售價(jià)合計(jì)(無(wú)格式)
);</p> <p>$uid=$_SESSION['user_id'];
if($uid==0){
$sql = "SELECT *, IF(parent_id, parent_id, goods_id) AS pid " .
" FROM " . $GLOBALS['ecs']->table('cart') . " " .
" WHERE session_id = '" . SESS_ID . "' AND rec_type = '" . CART_GENERAL_GOODS . "'" .
" ORDER BY pid, parent_id";}else{
$sql = "SELECT *, IF(parent_id, parent_id, goods_id) AS pid " .
" FROM " . $GLOBALS['ecs']->table('cart') . " " .
" WHERE (user_id='".$uid."' OR session_id = '" . SESS_ID . "') AND rec_type = '" . CART_GENERAL_GOODS . "'" .
" ORDER BY pid, parent_id";
}
$res = $GLOBALS['db']->query($sql);
//........后面不變
2. 購(gòu)物車內(nèi)容記錄方式,未登陸方式依然是Session , 用戶登陸后,自動(dòng)UPdate Cart 一次,將同一UserID下購(gòu)物車內(nèi)數(shù)據(jù)不是當(dāng)前Session的Update到當(dāng)前Session , 并將當(dāng)前Session 下UserID為0的部分(未登陸情況下,Userid是0),UpdateID到當(dāng)前UserID ,該修改位于 Flow.php 下面function flow_update_cart($arr)
{
foreach ($arr AS $key => $val)
{
$val = intval(make_semiangle($val));
if ($val <= 0)
{
continue;
}</p> <p> $sql = "SELECT `rec_id`, `goods_id`, `goods_attr_id`, `extension_code` FROM" .$GLOBALS['ecs']->table('cart').
" WHERE rec_id='$key' AND (session_id='" . SESS_ID . "' OR user_id='".$_SESSION['user_id']."')";</p> <p> $goods = $GLOBALS['db']->getRow($sql);
// 更新購(gòu)物車Session & user id
$sql ="UPDATE " .$GLOBALS['ecs']->table('cart')." SET session_id='" . SESS_ID . "',user_id='".$_SESSION['user_id']."' where rec_id='".$goods['rec_id']."'";
$g = $GLOBALS['db']->query($sql);
$sql = "SELECT g.goods_name, g.goods_number ".
"FROM " .$GLOBALS['ecs']->table('goods'). " AS g, ".
$GLOBALS['ecs']->table('cart'). " AS c ".
"WHERE g.goods_id = c.goods_id AND c.rec_id = '$key'";
//...........................后面不變
在用戶登陸后,F(xiàn)low.php打開(kāi)購(gòu)物車地方,需要調(diào)用一次自動(dòng)更新購(gòu)物車,
在$cart_goods = get_cart_goods();
之后增加如下代碼
$a[$cart_goods['goods_list'][$i]['rec_id']]=$cart_goods['goods_list'][0]['goods_number'];}
if(count($a)>0){flow_update_cart($a);}
第三項(xiàng)自己琢磨吧,懶得去翻那代碼了,改掉SQL語(yǔ)句中session_id部分為user_id就行了
希望本文所述對(duì)大家的ecshop二次開(kāi)發(fā)有所幫助。
相關(guān)文章
ecshop 二次開(kāi)發(fā) 加入用戶定制商品類型的方法
ecshop 二次開(kāi)發(fā) 加入用戶定制商品類型的方法,需要的朋友可以參考下2012-07-30ecshop二次開(kāi)發(fā) 購(gòu)物時(shí)為每件商品添加備注信息的修改方法
ecshop二次開(kāi)發(fā) 購(gòu)物時(shí)為每件商品添加備注信息的修改方法,需要的朋友可以參考下。2011-08-22Ecshop系統(tǒng)二次開(kāi)發(fā)教程及流程演示
Ecshop想必大家不會(huì)覺(jué)得陌生吧,大部分的B2C獨(dú)立網(wǎng)店系統(tǒng)都用的是Ecshop系統(tǒng),很受用戶的喜愛(ài),但是由于Ecshop模板自帶有很多Ecshop的Logo和版權(quán)信息,和一些其他需要修改2014-03-01ecshop二次開(kāi)發(fā)之常用函數(shù)匯總
這篇文章主要為大家介紹了ecshop二次開(kāi)發(fā)之常用函數(shù),匯總并說(shuō)明了ecshop二次開(kāi)發(fā)中常用的函數(shù)及其對(duì)應(yīng)的功能,具有很好的參考價(jià)值,需要的朋友可以參考下2014-11-19- ecshop調(diào)用指定分類的文章在網(wǎng)站中比較常用.下面來(lái)給朋友來(lái)介紹一下方法,參考一下不錯(cuò)的2012-05-21
ECSHOP安裝數(shù)據(jù)庫(kù)失敗date_default_timezone_get()問(wèn)題
今天在倒騰ECSHOP時(shí)遇到的問(wèn)題,以向?qū)J桨惭b時(shí)遇到具體的PHP警告如下2012-01-08ecshop安裝遇到安裝數(shù)據(jù)失敗的解決方法
在我第一次安裝ecshop時(shí)失敗了。提示遇到安裝數(shù)據(jù)失敗。并報(bào)出警告。2011-03-02- ECSHOP2.7版本的底部版權(quán)對(duì)于優(yōu)化與安全都不是很好,所以好多朋友都想給刪除了,下面的具體的方法,都是加密過(guò)的所有不容易簡(jiǎn)單的搜索.需要的朋友可以參考下。2010-01-24
ecshop 后臺(tái)登陸自動(dòng)退出的一種可能情況(目錄大小寫問(wèn)題)
某客戶的ecshop后臺(tái)登陸后,顯示成功,但是自動(dòng)退出到登陸界面,經(jīng)排查時(shí)因?yàn)槟夸洿笮憜?wèn)題2012-03-26- 首先聲明個(gè)人觀點(diǎn):不建議大家去除別人的版權(quán),請(qǐng)尊重知識(shí)產(chǎn)權(quán),特別是這樣好的系統(tǒng)。2010-01-24