为ecshop增加购物金额上限功能 – 千丝海阁

首页 » Ecshop » 为ecshop增加购物金额上限功能

为ecshop增加购物金额上限功能

2465 3

最近在接触Ecshop,国内最大的php开源电子商城系统,其后台默认管理页面里有一项功能是最小购物金额限制,通俗的讲就是当客户买的东西价格太小,没有利润可赚的时候,不允许用户提交订单。

ecshop

然而在现实的某些方面的交易中,我们可能还需要一个最大购物金额限制,所以此文的由来就是这里。初看,貌似很简单么,一个表单里加个inputtext,前面搞个label或者span写上“最大购物金额”,然后把该增加的inputtext的value存储到数据库里,可是事实上却并不是那么的简单。

先来看后台该选项的配置文件为/admin/shop_config.php,打开后,发现其文件内并没有任何直接可以预读到的东西,也没有呈现出上面所说的表单的基础结构。好吧,先看看文件内有些什么吧。很快找到下面那一行,得出选项存储的数据都存放在名为shop_config的table里。

$sql = "SELECT * FROM " . $ecs->table('shop_config') .
            " WHERE type<>'hidden' $config_groups $excludes_groups ORDER BY parent_id, sort_order, id";

文件末尾有个函数,读取配置到数组里变量存放,看来是用来直接读取数据库里的shop_config表里的各项的值。

/**
 * 获得设置信息
 *
 * @param   array   $groups     需要获得的设置组
 * @param   array   $excludes   不需要获得的设置组
 *
 * @return  array
 */
function get_settings($groups=null, $excludes=null)

那么shop_config里的数值是什么时候生成的呢?这个是安装初始化的时候写入到数据库里的,所以接下来打开shop_config表,很容易找到code为min_goods_amount的value为10。

ecshop3

parent_id对应的就是get_settings函数里的group,购物流程是第4个项目,所以这里是4:

ecshop2

然后根据上文提到的sql语句,基本可以判定按id大小顺序读取该表内容,然后呈现在Ecshop后台的配置选项中,尝试在表里最后直接添加一行数据:

ecshop4

另外需要自行调整对应的语言翻译文件/languages/zh_cn/admin/shop_config.php,对应位置添加下面两行。

$_LANG['cfg_name']['max_goods_amount'] = '最大购物金额';   
$_LANG['cfg_desc']['max_goods_amount'] = '低于此购物金额,才能提交订单。';

以及languages/zh_cn/shopping_flow里添加超过限额返回的提示内容。

$_LANG['goods_amount_not_enough'] = '您购买的商品没有达到本店的最低限购金额 %s ,不能提交订单。';

最终,刷新后台配置页面,显示如下:

ecshop5

当用户购买超过1000元的物品时:

ecshop6

前台返回错误页面给用户:

ecshop7

文章评分3次,平均分3.7



上一篇:衡天香港VPS配置VPN的PPTP
下一篇:WordPress技巧:解决无法加载预览图片

本文原始地址:http://www.tiandiyoyo.com/2014/07/add-max-money-limited-for-ecshop/
本站所有文章,除了特别注明外,均为本站原创,转载请注明出处来自www.tiandiyoyo.com

您可能还会对以下文章感兴趣:

评论前先开启评论开关:


3 Comments

  1. 购买东西居然还有金额限制,坑啊

  2. 购物还有限制金额的。

载入分页评论...