- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
ECSHOP源码分析(权限系统)
ECSHOP源码分析(权限系统)
第一部分ecshop权限系统介绍
(这部分熟悉了的朋友可以直接跳过,进入第二部分的代码分析)
这里是后台管理员的列表,我这里以admin管理员登陆进入后台的,admin管理员拥有所有的权限。
图1 后台管理员列表
如果想为某位管理员分派权限,点击分派权限按钮以后就会出现下面图片中的内容
图2 分派权限图
商品管理、文章管理、会员管理等都被精细的分成更多小的权限。图中的每一项小的权限都在数据库表中对应一个列数据。它被储存在数据表ecs_admin_action中。
图3 ecs_admin_action权限表的部分数据
该表中的action_code字段的值就是对应着各个权限。这个权限系统还涉及到另外一张表ecs_admin_user,下面的图片是表记录中的某一行记录,包括了这名管理员的一些基本信息。
图4 ecs_admin_user表中记录中的其中一行
与权限相关的字段是action_list,从以上图片中可以看到用户名为bjgonghuo1的管理员所有的权限在字段action_list中,action_list里面用逗号分割开的值对应着权限表ecs_admin_action中action_code的值。所以我要知道某个管理员的拥有哪些权限只需要查询这个ecs_action_user表中的action_list字段。
不同权限的管理员从后台登陆进去以后,看到的管理菜单是不一样的。下面图片是拥有全部权限的admin管理员登陆以后的管理菜单。
图5 管理员admin的权限管理菜单
以test03管理员登录后台看到的权限菜单则是
图6 管理员test03的后台权限管理菜单
第二部分 代码分析
登陆
某管理员登录的时候,就需要查询权限表,并将该管理员的权限放在session中。
if (md5($row[password] . $_CFG[hash_code]) == $_COOKIE[ECSCP][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_list’]存储了该管理员拥有了那些权限。
set_admin_session函数在ecshop/upload/admin/includes/lib_mains.php
/**
* 设置管理员的session内容
*
* @access public
* @param integer $user_id 管理员编号
* @param string $username 管理员姓名
* @param string $action_list 权限列表
* @param string $last_time 最后登录时间
* @return void
*/
function set_admin_session($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; // 用于保存最后一次检查订单的时间
}
分派权限
某管理员为其他管理员分派权限的相关代码位于
ecshop/upload/admin/privilege.php文件中
/*------------------------------------------------------ */
//-- 为管理员分配权限
/*------------------------------------------------------ */
elseif ($_REQUEST[act] == allot)
{
//该包含文件是ECSHOP 权限名称语言文件,主要用于多语言网站
include_
您可能关注的文档
最近下载
- 平狄克-微观经济学-第七版--课件.ppt VIP
- 电线电缆质量手册范本.doc VIP
- 中职英语高教版(2025)基础模块1Unit 1 Personal and Family Life 单词课件(共20张ppt)(含音频+视频).pptx VIP
- 2025年高考语文一轮复习考点通关【语言文字运用】考点38 正确使用词语(含答案).docx VIP
- 猜谜语-动物(十六).docx VIP
- 2025年高考语文一轮复习考点通关【语言文字运用】考点41 辨析与鉴赏修辞手法(含答案).docx VIP
- 沃森(VicRuns)VD120A-GS系列变频器说明书用户手册.doc
- 2025年10月离任审计述职报告范文模板.docx VIP
- 2024年《社区JW工作规范(试行)》题库.docx
- 跨境电商客户服务课件:学习情境四 跨境电子商务售中沟通与服务.pptx VIP
文档评论(0)