ecshop退出登錄後,會清空購物車,你們都應該知道有這樣的勉強算bug的問題。 網上相似的教程至關多,但都有問題,說句很差聽的,算是引新手入歧途!php
總結網上方法以下:sql
一、修改init.php,把sess_id綁定ip的。老楊點評:各類紊亂不解釋。瀏覽器
二、修改cls_session.php,讓user_id不爲0的購物車商品在退出時不刪除,修改lib_main.php,將購物車中sess_id換成新的session_id。 老楊點評:算是到了點子上的改法,可是在不一樣設置或瀏覽器訪問時,會照成其它設備上的出問題!必須從新登陸才能解決!在手機流行的年代,若是手機和pc同時登陸,或兩臺電腦檯時登陸,你會崩潰的,登了這邊,那邊購物車就空了,除非從新登陸!session
三、其它的方法,各類坑,再也不列舉。this
方法:加密
一、修改includes/cls_session.php 找到(268行左右):spa
if (!empty($GLOBALS['ecs'])) { $this->db->query('DELETE FROM ' . $GLOBALS['ecs']->table('cart') . " WHERE session_id = '$this->session_id' ); }
替換爲:code
if (!emptyempty($GLOBALS['ecs'])) { $this->db->query('DELETE FROM ' . $GLOBALS['ecs']->table('cart') . " WHERE session_id = '$this->session_id' AND user_id = 0");//www.lyecs.com 只清空匿名** }
二、找到includes/init.phpblog
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,www.lyecs.com $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 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()); }
三、同理,mobile/includes/init.php也改下。第2條是重點,已所有註釋