开发交流

老杨原创-ecshop退出登录会清空购物车的bug优化,最完美解决方法

LYECS,LYECS+商城系统,多用户商城系统,开源商城系统 发布日期:2014-10-25   作者:老杨

该教程2015.5.21日有更新

ecshop退出登陆后,会清空购物车,大家都应该知道有这样的勉强算bug的问题。

网上类似的教程相当多,但都有问题,说句不好听的,算是引新手入歧途!

总结网上方法如下:

1、修改init.php,把sess_id绑定ip的。老杨点评:各种紊乱不解释。

2、修改cls_session.php,让user_id不为0的购物车商品在退出时不删除,修改lib_main.php,将购物车中sess_id换成新的session_id。

老杨点评:算是到了点子上的改法,但是在不同设置或浏览器访问时,会照成其它设备上的出问题!必须重新登录才能解决!在手机流行的年代,如果手机和pc同时登录,或两台电脑台时登录,你会崩溃的,登了这边,那边购物车就空了,除非重新登录!

 

3、其它的方法,各种坑,不再列举。

老杨的方法(2015.5.21日更新):

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' );
        }

替换为:


复制内容到剪贴板
  1. if (!empty($GLOBALS['ecs']))  
  2. {  
  3.     $this->db->query('DELETE FROM ' . $GLOBALS['ecs']->table('cart') . " WHERE session_id = '$this->session_id' AND user_id = 0");//www.lyecs.com 老杨ecshop 只清空匿名购买  
  4. }  

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,www.lyecs.com 老杨lyecs  
            $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  www.lyecs.com 老杨lyecs  
            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());  
    } 



 3、找到includes/lib_order.php

查找:


复制内容到剪贴板
  1. function get_cart_goods($is_order=false)  
  2. {  

替换为:


复制内容到剪贴板
  1. function get_cart_goods($is_order=false)  
  2. {  
  3.     /*获取原有购物车与会员购物合并处理  www.lyecs.com*/  
  4.     $sql = "SELECT rec_id,goods_id,product_id,goods_number,goods_attr,is_gift,parent_id " .  
  5.             " FROM " . $GLOBALS['ecs']->table('cart') . " WHERE session_id='".OLD_SESS_ID."' ";   
  6.     $old_res = $GLOBALS['db']->getAll($sql);  
  7.     if($old_res){  
  8.         foreach ($old_res as $key => $row){  
  9.             $sql = "SELECT rec_id FROM " . $GLOBALS['ecs']->table('cart') . " WHERE user_id='".$_SESSION['user_id']."'".  
  10.                 " AND goods_id='".$row['goods_id']."' AND product_id='".$row['product_id']."' AND is_gift='".$row['is_gift']."' AND parent_id='".$row['parent_id']."' ";   
  11.             $repeat_rec_id = $GLOBALS['db']->getOne($sql);  
  12.             if($repeat_rec_id ){  
  13.                 $sql="update ".$GLOBALS['ecs']->table('cart')."set goods_number=(goods_number+$row[goods_number]) where rec_id='".$repeat_rec_id."' ";    
  14.                 $GLOBALS['db']->query($sql);   
  15.                 $sql = "DELETE FROM " . $GLOBALS['ecs']->table('cart') . "WHERE rec_id ='$row[rec_id]'";  
  16.                 $GLOBALS['db']->query($sql);  
  17.             }else{  
  18.                 $sql="update ".$GLOBALS['ecs']->table('cart')."set session_id='SESS_ID',user_id='".$_SESSION['user_id']."' where rec_id='$row[rec_id]' ";    
  19.                 $GLOBALS['db']->query($sql);    
  20.             }  
  21.         }  
  22.     }  

4、同理,mobile/includes/init.php也改改。

第2、3条是重点,老杨已全部注释,有精力的可以自己研究下!

转载请注明出处!

 
 

热门文章

分类标签