ECSHOP源码分析(权限系统)

ECSHOP源码分析(权限系统)

ID:40536971

大小:143.50 KB

页数:9页

时间:2019-08-04

ECSHOP源码分析(权限系统)_第1页
ECSHOP源码分析(权限系统)_第2页
ECSHOP源码分析(权限系统)_第3页
ECSHOP源码分析(权限系统)_第4页
ECSHOP源码分析(权限系统)_第5页
资源描述:

《ECSHOP源码分析(权限系统)》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、ECSHOP源码分析(权限系统)第一部分ecshop权限系统介绍(这部分熟悉了的朋友可以直接跳过,进入第二部分的代码分析)这里是后台管理员的列表,我这里以admin管理员登陆进入后台的,admin管理员拥有所有的权限。图1后台管理员列表如果想为某位管理员分派权限,点击分派权限按钮以后就会出现下面图片中的内容9图2分派权限图商品管理、文章管理、会员管理等都被精细的分成更多小的权限。图中的每一项小的权限都在数据库表中对应一个列数据。它被储存在数据表ecs_admin_action中。图3ecs_admin_action权限表的部分数据

2、该表中的action_code字段的值就是对应着各个权限。这个权限系统还涉及到另外一张表ecs_admin_user,下面的图片是表记录中的某一行记录,包括了这名管理员的一些基本信息。9图4ecs_admin_user表中记录中的其中一行与权限相关的字段是action_list,从以上图片中可以看到用户名为bjgonghuo1的管理员所有的权限在字段action_list中,action_list里面用逗号分割开的值对应着权限表ecs_admin_action中action_code的值。所以我要知道某个管理员的拥有哪些权限只需要

3、查询这个ecs_action_user表中的action_list字段。不同权限的管理员从后台登陆进去以后,看到的管理菜单是不一样的。下面图片是拥有全部权限的admin管理员登陆以后的管理菜单。9图5管理员admin的权限管理菜单以test03管理员登录后台看到的权限菜单则是9图6管理员test03的后台权限管理菜单9第二部分代码分析登陆某管理员登录的时候,就需要查询权限表,并将该管理员的权限放在session中。if(md5($row['password'].$_CFG['hash_code'])==$_COOKIE['ECSC

4、P']['admin_pass']){!isset($row['last_time'])&&$row['last_time']='';set_admin_session($row['user_id'],$row['user_name'],$row['action_list'],$row['last_time']); 以上这段代码在ecshop/upload/admin/includes/init.php的253行附近。其中set_admin_session函数用来将一些信息记录到session中去的,$row[‘action_li

5、st’]存储了该管理员拥有了那些权限。set_admin_session函数在ecshop/upload/admin/includes/lib_mains.php/***设置管理员的session内容**@accesspublic*@paraminteger$user_id管理员编号*@paramstring$username管理员姓名*@paramstring$action_list权限列表*@paramstring$last_time最后登录时间*@returnvoid*/functionset_admin_session($

6、user_id,$username,$action_list,$last_time){$_SESSION['admin_id']=$user_id;$_SESSION['admin_name']=$username;$_SESSION['action_list']=$action_list;$_SESSION['last_check']=$last_time;//用于保存最后一次检查订单的时间}9分派权限某管理员为其他管理员分派权限的相关代码位于ecshop/upload/admin/privilege.php文件中/*-----

7、-------------------------------------------------*///--为管理员分配权限/*------------------------------------------------------*/elseif($_REQUEST['act']=='allot'){//该包含文件是ECSHOP权限名称语言文件,主要用于多语言网站include_once(ROOT_PATH.'languages/'.$_CFG['lang'].'/admin/priv_action.php');/*判断该

8、管理员是否拥有“allot_priv”权限,拥有‘allot_priv’权限的管理员才能为其他用户设置权限*/admin_priv('allot_priv');if($_SESSION['admin_id']==$_GET['id']){admin

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。