您现在的位置是:首页 > cms教程 > Ecshop商城教程Ecshop商城教程
ecshop修改处理用户购物车的行为的方法
沛珊2025-01-06Ecshop商城教程已有人查阅
导读Ecshop v2.7.3的购物车处理方面在现在看来有比较反用户体验的设计:用户未登录时加入购物车的商品,在用户登录后会被清空而不是加入到登录用户的购物车中;
Ecshop v2.7.3的购物车处理方面在现在看来有比较反用户体验的设计:用户未登录时加入购物车的商品,在用户登录后会被清空而不是加入到登录用户的购物车中;
用户登录后加入购物车的商品,在退出后会被清空。
这两种设计在现在看来简直不可理喻,对用户极不友好,作为一个以流量至上的商城,这样的设计会导致客户的流失。
查看源码才发现,ecshop是以session_id作为保存购物车商品的依据,而不是用户id。个人认为这样的设计是由于其以下单为主,用户有没有注册都可以直接下单,这样就导致其整套逻辑以"会话”为主体。
修改ecshop购物车行为,使其以客户为主,具体设计是:
用户登录后加入购物车的商品,退出后依然保留;
用户未登录时加入购物车的商品:
如果用户登录,则合并到客户的购物车中;
如果未登录即关闭,则保存到cookie中一段时间(ecshop本身已实现)
策略:
1.登录前用session_id,登录后用user_id查看,操作购物车数据;
2.用户登录后,更新合并购物车数据;
3.用户登出后,依然有无主商品的话,删除。
lib_main.php添加。
cls_session.php修改函数
1 update_user_info(); //更新用户信息
2 /*如果用户已登录且其在未登录时将商品加入了购物车,那么将未登录时的购物车与用户之前的购物车商品合并*/
3 update_user_cart();//新加上
4 recalculate_price(); // 重新计算购物车中的商品价格
flow.php , lib_insert.php,lib_main.php,lib_order.php , lib_transaction.php ,order.php 等内容中的 session_id='".SESS_ID."'"改为 rec_select();
测试看看。
用户登录后加入购物车的商品,在退出后会被清空。
这两种设计在现在看来简直不可理喻,对用户极不友好,作为一个以流量至上的商城,这样的设计会导致客户的流失。
查看源码才发现,ecshop是以session_id作为保存购物车商品的依据,而不是用户id。个人认为这样的设计是由于其以下单为主,用户有没有注册都可以直接下单,这样就导致其整套逻辑以"会话”为主体。
修改ecshop购物车行为,使其以客户为主,具体设计是:
用户登录后加入购物车的商品,退出后依然保留;
用户未登录时加入购物车的商品:
如果用户登录,则合并到客户的购物车中;
如果未登录即关闭,则保存到cookie中一段时间(ecshop本身已实现)
策略:
1.登录前用session_id,登录后用user_id查看,操作购物车数据;
2.用户登录后,更新合并购物车数据;
3.用户登出后,依然有无主商品的话,删除。
lib_main.php添加。
1 /**
2 * 选择购物车商品的获取条件
3 * Desc: 如果已登录,返回user_id条件,否则返回session_id条件
4 * @access public
5 * @return where condition
6 */
7 function rec_select()
8 {
9 return (isset($_SESSION['user_id'])&&intval($_SESSION['user_id'])>0)?"user_id= ".intval($_SESSION['user_id'])." ":"session_id = '" . SESS_ID . "' ";
10 }
11
12 /**
13 * 更新购物车中的商品
14 * Desc: 如果用户已登录且其在未登录时将商品加入了购物车,那么将未登录时的购物车与用户之前的购物车商品合并
15 * @access public
16 * @return boolean
17 */
18 function update_user_cart()
19 {
20 if(!isset($_SESSION['user_id']))
21 return FALSE;
22
23 /*查看是否有未登录时加入购物车的商品*/
24 $sql = "SELECT *, IF(parent_id, parent_id, goods_id) AS pid " .
25 " FROM " . $GLOBALS['ecs']->table('cart') . " " .
26 " WHERE session_id = '" . SESS_ID . "' AND user_id=0 AND rec_type = '" . CART_GENERAL_GOODS . "'" .
27 " ORDER BY pid, parent_id";
28 $res = $GLOBALS['db']->query($sql);
29
30 $_uid=intval($_SESSION['user_id']);
31
32 while ($row = $GLOBALS['db']->fetchRow($res))
33 {
34 if($_uid>0)
35 {
36 /* 检查该商品是否已经存在在购物车中 */
37 $sql="SELECT * FROM {$GLOBALS['ecs']->table('cart')} WHERE user_id={$_uid} AND goods_id={$row['goods_id']} AND rec_type = '" . CART_GENERAL_GOODS."'
38 AND goods_attr='{$row['goods_attr']}'
39 AND goods_attr_id={$row['goods_attr_id']}
40 AND product_id={$row['product_id']}
41 AND parent_id={$row['parent_id']}
42 AND is_gift={$row['is_gift']}
43 AND is_shipping={$row['is_shipping']}
44 ";
45 $_one=$GLOBALS['db']->getOne($sql);
46
47 if(!empty($_one))
48 {
49 $goods_number=$_one['goods_number']+$row['goods_number'];
50 $sql="UPDATE {$GLOBALS['ecs']->table('cart')} SET goods_number = {$goods_number} WHERE rec_id = {$_one['rec_id']}";
51 $GLOBALS['db']->query($sql);
52
53 $sql="DELETE FROM {$GLOBALS['ecs']->table('cart')} WHERE rec_id = {$row['rec_id']}";
54 $GLOBALS['db']->query($sql);
55 }
56 else
57 {
58 $sql="UPDATE {$GLOBALS['ecs']->table('cart')} SET user_id = {$_uid} WHERE rec_id = {$row['rec_id']}";
59 $GLOBALS['db']->query($sql);
60 }
61
62 }
63 }
64 return TRUE;
65 }
核心代码cls_session.php修改函数
function destroy_session()
{
$GLOBALS['_SESSION'] = array();
setcookie($this->session_name, $this->session_id, 1, $this->session_cookie_path, $this->session_cookie_domain, $this->session_cookie_secure);
/* ECSHOP 鑷?畾涔夋墽琛岄儴鍒 */
/*
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");
}
/* ECSHOP 鑷?畾涔夋墽琛岄儴鍒 */
$this->db->query('DELETE FROM ' . $this->session_data_table . " WHERE sesskey = '" . $this->session_id . "' LIMIT 1");
return $this->db->query('DELETE FROM ' . $this->session_table . " WHERE sesskey = '" . $this->session_id . "' LIMIT 1");
}
flow.php 在act=login,已登录的处理函数后;act=add_to_cart 加入购物车后,user.php action=act_login登录后加上1 update_user_info(); //更新用户信息
2 /*如果用户已登录且其在未登录时将商品加入了购物车,那么将未登录时的购物车与用户之前的购物车商品合并*/
3 update_user_cart();//新加上
4 recalculate_price(); // 重新计算购物车中的商品价格
flow.php , lib_insert.php,lib_main.php,lib_order.php , lib_transaction.php ,order.php 等内容中的 session_id='".SESS_ID."'"改为 rec_select();
测试看看。
本文标签:
很赞哦! ()
图文教程
ecshop漏洞search.php SQL Injection Vul
catalog1. 漏洞描述2. 漏洞触发条件3. 漏洞影响范围4. 漏洞代码分析5. 防御方法6. 攻防思考1. 漏洞描述ECSHOP商城系统Search.php页面过滤不严导致SQL注入漏洞
ecshop分词搜索和商品关键字红色的实现方法
最近在用ECSHOP做一个商城,发现ECSHOP的模糊搜索要求太高,需要加入and、空格、加号等,客户搜索的时候不可能这样操作。所以想对搜索功能进行改进
ecshop调用指定分类下文章的方法
ecshop调用指定文章分类的方法,例如调用分类ID为5的文章,1、先打开index.php文件找到以下代码:2、在lib_goods.php增加以下函数
ecshop转换后图片路径处理办法
从shopex转换过来后,ecshop的 图片地址都会是http://lwww.ebingou.cn/aa.jpg而ecshop转成功后程序copy图片路径是
相关源码
-
(PC+WAP)绿色市政园林建筑设计绿化营销型pbootcms网站模板本模板基于PbootCMS系统开发,为园林绿化、景观设计类企业设计,特别适合市政园林、景观工程、绿化养护等企业使用。采用双端适配技术查看源码 -
(自适应响应式)化妆美容口红唇膏化妆品模板pbootcms源码下载基于PbootCMS开发的响应式模板,为化妆品品牌、美容机构打造,通过优雅的视觉呈现提升产品展示效果与品牌调性。采用时尚杂志排版风格,色卡系统规范产品展示。微交互动画增强用户体验,智能推荐算法提升产品关联展示效果。查看源码 -
(自适应)大型农业机械设备水稻玉米收割机网站pbootcms源码下载本模板基于PbootCMS内核开发,为农业机械设备制造与销售企业设计,特别适合水稻玉米收割机、拖拉机、播种机等农用机械展示。模板充分考虑了农机行业的特性,从产品展示到技术参数,从作业案例到售后服务查看源码 -
(自适应)大气壁挂炉暖气设备家用电器模板带加盟申请和下载资料为壁挂炉、暖气片等供暖设备企业设计的PbootCMS模板,通过响应式技术实现跨终端展示产品参数和技术细节。后台统一管理确保采暖系统数据、服务网点信息实时同步更新查看源码 -
(PC+WAP)企业管理工程造价资产评估财务审计带留言网站模板本模板基于PbootCMS内核开发,为工程造价咨询、财务审计类企业量身打造,同时支持多行业快速适配。采用PC+WAP双端同步设计,数据实时互通,助您高效展示企业形象与服务能力。查看源码 -
帝国cms7.5商城模板带图片视频广告位功能本模板基于帝国CMS7.5内核开发,为内容电商平台设计,集成文章、图片、视频多媒体展示与广告位管理功能。采用智能响应式技术,确保商品内容在不同设备上获得较优呈现效果,帮助快速构建专业的内容营销平台。查看源码
| 分享笔记 (共有 篇笔记) |