ecshop退出登陸后,會清空購物車,大家都應該知道有這樣的勉強算bug的問題。
網上類似的教程相當多,但都有問題,說句不好聽的,算是引新手入歧途!
總結網上方法如下:
1、修改init.php,把sess_id綁定ip的。A5源碼點評:各種紊亂不解釋。
2、修改cls_session.php,讓user_id不為0的購物車商品在退出時不刪除,修改lib_main.php,將購物車中sess_id換成新的session_id。
A5源碼點評:算是到了點子上的改法,但是在不同設置或瀏覽器訪問時,會照成其它設備上的出問題!必須重新登錄商城模板才能解決!在手機流行的年代,如果手機和pc同時登錄,或兩臺電腦臺時登錄,你會崩潰的,登了這邊,那邊購物車就空了,除非重新登錄!
3、其它的方法,各種坑,不再列舉。
A5源碼的方法:
1、修改includes/cls_session.php
找到(268行左右):
if (!empty($GLOBALS['ecs']))
{
$this->db->query('DELETE FROM ' .
$GLOBALS['ecs']->table('cart') . " WHERE session_id =
'$this->session_id' );
}
替換為:
if (!empty($GLOBALS['ecs']))
{
$this->db->query('DELETE FROM ' . $GLOBALS['ecs']->table('cart') . " WHERE session_id = '$this->session_id' AND user_id = 0");//down.vevb.com/info A5源碼ecshop 只清空匿名**
}
2、找到includes/init.php
define('SESS_ID', $sess->get_session_id());
替換為:
//判斷是否存在user_id的session,避免高版本PHP報錯
if(isset($_SESSION['user_id'])){
//如果存在會員登錄
if($_SESSION['user_id']>0){
//取得對應user_id的session MD5碼,后面加入'@lyecs.com'自定義的自符串加密。
$user_session=md5($_SESSION['user_id'].'@lyecs.com'); //'@lyecs.com'內容可自行修改
//取得之前的session_id,down.vevb.com/info A5源碼ecshop
$old_session=$sess->get_session_id();
//如果會員的session_id和原先的session_id不同(則為新登錄情況),則將購物車內原session_id的商品,更新為會員下的商品!
if($user_session != $old_session){
$sql="update ".$GLOBALS['ecs']->table('cart')."set session_id='".$user_session."',user_id='".$_SESSION['user_id']."' where session_id='".$old_session."' ";
$GLOBALS['db']->query($sql);
}
//定義新的會員唯一session_id down.vevb.com/info A5源碼ecshop
define('SESS_ID',$user_session);
}else{
//不存在會員,繼續用原有的session_id
define('SESS_ID', $sess->get_session_id());
}
}else{
//不存在會員,繼續用原有的session_id
define('SESS_ID', $sess->get_session_id());
}
新聞熱點
疑難解答