thinkphp自定义权限管理之名称判断方法
权限管理,就是给不同的用户分配不同的权限。当用户登录或者操作时候进行判断,来阻止用户进行权限以外的操作。本次讲的是当用户登录一刻,只显示权限开启的内容。
一、建立数据库。
1、权限表funcla。来存储录入所有权限,也是避免因权限名称修改了,权限失效的问题。
2、管理员表admin。主要存储管理员用户名等信息。
3、管理员对应权限表funadmin。主要存储已开启的管理员id与权限id。
二、输出权限列表。
1、通过管理员列表进入权限分配。
2、权限分配列表。
关于权限分配列表,因为权限板块的不同,我们需要区别顶级分类与其子集。并且还需要显示权限状态。在权限状态判断中也使用了一层循环判断。代码中采用了三层嵌套循环输出。
具体代码如下
<div>分配管理员{$username}的权限</div> <table width="100%" border="0" cellpadding="0" cellspacing="0" class="list_table mt10"> <tr> <th>权限名称</th> <th>状态</th> </tr> <volist name="funcla" id="v" key="j"> <tr class="tr"> <td>{$v.claname}</td> <td><input <volist name="funadmin" id="d"><if condition="$d['funclaid'] eq $v['id']">checked</if></volist> type="checkbox" id="{$v.id}" name="{$userid}" onchange="return setfun(this,seturl)" /></td> </tr> <volist name="fun" id="vo"> <if condition="$vo['clapid'] eq $v['id']"> <tr class="tr"> <td style="padding-left: 40px;" >{$vo.claname}</td> <td> <input <volist name="funadmin" id="d"><if condition="$d['funclaid'] eq $vo['id']">checked</if></volist> type="checkbox" id="{$vo.id}" name="{$userid}" onchange="return setfun(this,seturl)" /> </td> </tr> </if> </volist> </volist> </table>
循环示例图如:
3、具体控制器如下:
public function setfun(){ $uid=I('get.id',0,'int'); $a=M('admin'); $user=$a->where(array(id=>$uid))->field('username,id')->find(); $this->username=$user['username']; $this->userid=$user['id']; $m=M('funcla'); $funcla=$m->where(array(clapid=>'0'))->field(true)->select(); $fun=$m->field(true)->select(); $this->fun=$fun; $this->funcla=$funcla; $fd=M('funadmin'); $funadmin=$fd->where(array(adminid=>$uid))->field(true)->select(); $this->funadmin=$funadmin; $this->display(); }
4、js。当用户权限发生改变时,即触发js提交json,向控制器传递数据参数。
function setfun(t,u){ var id=$(t).attr('id'); var uid=$(t).attr('name'); var type=$(t).is(":checked")?1:0; var url=u; $.ajax({ url:url, type:'post', data:{ id:id, type:type, uid:uid }, success:function(data){ }, error:function(data){ } }) }
json传递的url地址用过页面中实例化地址获取。如:
<script type="text/javascript"> var seturl="{:U("Admin/chanefun")}"; </script>
三、控制器获取json的数据参数,判断权限的添加与修改。如果是添加,就向funadmin表中添加受理权限人id与要授权的权限id作为一条数据。修改即删除符合条件的一条数据。同理。
public function chanefun(){ $m=M('funadmin'); $where['funclaid']=I('post.id',0,'int'); $where['adminid']=I('post.uid',0,'int'); $type=I('post.type',0,'int'); if(empty($type)){ $oid=$m->where($where)->getfield('id'); $m->delete($oid); return; } $m->data($where)->add(); }
四、真实权限判断。前面都是为权限判断做准备的,现在才是真正的判断,基本原理是把要判断的权限名称与当前登录用户id拿到funadmin表中对比,如有发现则,说明该用户有权限,即显示,否则影藏。影藏了是看不到链接地址,但是如果知道地址则可以通过地址直接访问。
(1)前台判断显示与否。调用了自定义方法chackQ();
<if condition="chackQ('任务管理')"> <li><a href="{:U('taskinfo/dir')}" rel="external nofollow" >任务管理</a></li> </if>
(2) 具体对比操作。
function chackQ($name,$state=false){ if(!$state){ exit; } $fun=M('funcla'); $funclaid=$fun->where(array(claname=>$name))->getfield('id'); $m=M('funadmin'); $adminid=session('admin_userid'); $reset=$m->where(array(funclaid=>$funclaid,adminid=>$adminid))->find(); if(empty($reset)){ echo "你没有权限"; exit; } return $reset; }
至此,整个权限控制基本完成。
(资源库 www.zyku.net)
您可能感兴趣的文章
- 03-13PHP巧妙利用位运算实现网站权限管理的方法
- 03-20黑鲨4屏蔽系统工具广告操作方法
- 10-18小米11Ultra如何开启车道级导航
- 01-12乐学普通话-乐学普通话应用软件功能介
- 03-15荣耀50se隐藏应用步骤操作方法
- 01-23华为mate40怎么设置全屏拍照
- 03-28vivos7e来信息手电筒闪烁功能使用教程
- 02-23一加9r启动双wifi网络加速方法
- 10-15iphone13pro刷新率怎么调节
- 09-16小米手机如何添加游戏加速到桌面
- 03-04红米note10局部截屏使用方法
- 03-03WordPress后台显示未回复的评论的方法
- 03-19oppor15电源键唤醒语音助手方法
- 08-19抖音网页版取消定时发布作品
- 11-13小米11怎么设置来电转接
- 09-17keep手环如何绑定手机
- 08-30织梦DedeCMS获取文章链接的函数GetOne
- 01-12致用历史-致用历史应用软件功能介绍
- 01-24华为手机导航键开启方法
- 12-26磕物-磕物应用软件功能介绍
最近更新
阅读排行
猜你喜欢
- 03-31CentOS 7 开机/etc/rc.local 不执行的
- 01-12讯编手机表格Excel-讯编手机表格Excel
- 12-22HTML <embed> 标签
- 07-04vivos10pro设置隔空解锁教程
- 03-18phpStudy设置允许远程访问MySQL数据库
- 11-16sony耳机蓝牙配对苹果手机方法介绍
- 08-30Vtigercrm报错Sorry! Attempt to acce
- 03-20魅族18pro锁屏时间修改方法
- 01-11指连WiFi-指连WiFi应用软件功能介绍
- 01-08一寸照证件制作-一寸照证件制作应用软