您好,登錄后才能下訂單哦!
本篇內容主要講解“thinkphp自定義權限管理名稱判斷方法是什么”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“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 >{$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; }
至此,整個權限控制基本完成。
到此,相信大家對“thinkphp自定義權限管理名稱判斷方法是什么”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。