ECSHOP后台二次开发教程(一)

2016-06-13 13:05 来源:www.chinab4c.com 作者:ecshop专家

ECSHOP后台开发模块步骤   一、建数据库 二、添加到后台导航栏并配置相关语言包 三、权限配置 四、添加增删查改 五、增加其他功能(复制,搜索(暂时调不出来页面),排序,转移,AJAX) 以添加支付信息模块为例 第一步首先我们用phpmyadmin建一个支付表,表名:ecs_pay表字段:pay_id,pay_name,pay_info,pay_bank,pay_credit,pay_state第二步添加到后台左侧导航栏并配置权限和相关语言包 共修改四个文件inc_priv.php、   inc_menu.php 、priv_action.php、common.php 1.打开languages\zh_cn\admin\common.php 找到/* 菜单分类部分 */ 添加   $_LANG['18_pay'] = '支付管理'; 文件末尾添加 /* 支付管理 */ $_LANG['02_pay_list'] = '支付人信息'; $_LANG['03_pay_charge'] = '账户充值'; $_LANG['04_pay_record'] = '流水记账'; 配其他相关的语言包 $_LANG['pay_name'] = '支付人'; $_LANG['pay_info'] = '支付信息'; $_LANG['pay_bank'] = '开户银行'; $_LANG['pay_credit'] = '开户帐号'; $_LANG['pay_state'] = '状态'; 2.打开admin\includes\inc_menu.php 末尾添加 $modules['18_pay']['02_pay_info']     = 'pay.php?act=list'; $modules['18_pay']['03_pay_charge'] = 'pay.php?act=charge'; $modules['18_pay']['04_pay_record']     = 'pay.php?act=record'; OK,菜单栏显示 第三步 配置权限体系(priv_action.php ,inc_priv.php) 1.在表ecs_admin_action 里面添加模块字段pay 、pay_manage、 pay_drop parent_id = 0的为顶级栏目,其他子栏目的操作,都继承了parent_id 和顶级栏目关联起来.(注意action_id  和parent_id 的关系 ) 添加一个顶级栏目   pay action_id为136   parent_id 为0;    其下子栏目   pay_manage        parent_id 为136;               pay_drop           parent_id 为136; 2.打开languages\zh_cn\admin\priv_action.php /* 权限管理的一级分组 */下添加 $_LANG['pay']       = '支付管理'; 末尾添加 //支付管理 $_LANG['pay_manage'] = '支付添加/编辑'; $_LANG['pay_drop'] = '支付删除'; 3.打开admin\includes\inc_priv.php 末尾添加 //支付管理 $purview['02_pay_info']       = array('pay_manage', 'pay_drop'); $purview['03_pay_charge']        = 'pay_manage'; $purview['04_pay_record']    = 'pay_manage'; 第四步,添加基本的增删改查功能 建四个文件 pay.php、pay_list、pay_info、pay_search .添加“增加”功能 /*------------------------------------------------------ */ //-- 添加支付人信息 /*------------------------------------------------------ */ if ($_REQUEST['act'] == 'add') { /* 权限判断 */ // admin_priv('pay_manage'); /*初始化*/ $smarty->assign('ur_here', $_LANG['pay_name_add']); //$smarty->assign('action_link', array('text' => $_LANG['pay_name_add'], 'href' => 'pay.php?act=list'));     $smarty->assign('form', 'insert'); assign_query_info(); $smarty->display('pay_info.htm'); } /*------------------------------------------------------ */ //-- 添加支付人信息 /*------------------------------------------------------ */ if ($_REQUEST['act'] == 'insert') { /* 权限判断 */ //admin_priv('pay_manage'); /*检查是否重复*/ $is_only = $exc->is_only('pay_id', $_POST['pay_id'],0, " pay_id ='$_POST[pay_id]'"); if (!$is_only) {        sys_msg($_LANG['goods_exist'], 1); } /*插入数据*/ if (empty($_POST['pay_id'])) {        $_POST['pay_id'] = 0; } $sql = "INSERT INTO ".$ecs->table('pay')."(pay_id, pay_name,pay_info, pay_bank, pay_credit) ".          "VALUES ('$_POST[pay_id]','$_POST[pay_name]', '$_POST[pay_info]', '$_POST[pay_bank]', '$_POST[pay_credit]')"; $db->query($sql); $link[0]['text'] = $_LANG['back_list']; $link[0]['href'] = 'pay.php?act=list'; $link[1]['text'] = $_LANG['pay_continue_add']; $link[1]['href'] = 'pay.php?act=add';   admin_log($_POST['pay_id'],'add','exchange_goods'); clear_cache_files(); // 清除相关的缓存文件 sys_msg($_LANG['articleadd_succeed'],0, $link); } (首先是根据act传来的参数add,把参数insert赋值到smarty模板,放在在添加页面隐藏域中,更新也是如此)   1.根据传递过来的act的参数insert逻辑添加处理,(参数insert在添加页面的)   2.admin_priv函数判断是否具有权限,   3.$exc->is_only()判断自增号是否唯一(可去掉)   4.$db->query($sql)对数据库进行操作,   5.admin_log()函数记录操作信息   6.clear_cache_files();清除缓存   7.sys_msg()函数提示操作信息