thinkphp自定義權(quán)限管理之名稱(chēng)判斷方法
權(quán)限管理,就是給不同的用戶(hù)分配不同的權(quán)限。當(dāng)用戶(hù)登錄或者操作時(shí)候進(jìn)行判斷,來(lái)阻止用戶(hù)進(jìn)行權(quán)限以外的操作。本次講的是當(dāng)用戶(hù)登錄一刻,只顯示權(quán)限開(kāi)啟的內(nèi)容。
一、建立數(shù)據(jù)庫(kù)。
1、權(quán)限表funcla。來(lái)存儲(chǔ)錄入所有權(quán)限,也是避免因權(quán)限名稱(chēng)修改了,權(quán)限失效的問(wèn)題。
2、管理員表admin。主要存儲(chǔ)管理員用戶(hù)名等信息。
3、管理員對(duì)應(yīng)權(quán)限表funadmin。主要存儲(chǔ)已開(kāi)啟的管理員id與權(quán)限id。
二、輸出權(quán)限列表。
1、通過(guò)管理員列表進(jìn)入權(quán)限分配。
2、權(quán)限分配列表。
關(guān)于權(quán)限分配列表,因?yàn)闄?quán)限板塊的不同,我們需要區(qū)別頂級(jí)分類(lèi)與其子集。并且還需要顯示權(quán)限狀態(tài)。在權(quán)限狀態(tài)判斷中也使用了一層循環(huán)判斷。代碼中采用了三層嵌套循環(huán)輸出。
具體代碼如下
<div>分配管理員{$username}的權(quán)限</div> <table width="100%" border="0" cellpadding="0" cellspacing="0" class="list_table mt10"> <tr> <th>權(quán)限名稱(chēng)</th> <th>狀態(tài)</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。當(dāng)用戶(hù)權(quán)限發(fā)生改變時(shí),即觸發(fā)js提交json,向控制器傳遞數(shù)據(jù)參數(shù)。
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地址用過(guò)頁(yè)面中實(shí)例化地址獲取。如:
<script type="text/javascript"> var seturl="{:U("Admin/chanefun")}"; </script>
三、控制器獲取json的數(shù)據(jù)參數(shù),判斷權(quán)限的添加與修改。如果是添加,就向funadmin表中添加受理權(quán)限人id與要授權(quán)的權(quán)限id作為一條數(shù)據(jù)。修改即刪除符合條件的一條數(shù)據(jù)。同理。
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(); }
四、真實(shí)權(quán)限判斷。前面都是為權(quán)限判斷做準(zhǔn)備的,現(xiàn)在才是真正的判斷,基本原理是把要判斷的權(quán)限名稱(chēng)與當(dāng)前登錄用戶(hù)id拿到funadmin表中對(duì)比,如有發(fā)現(xiàn)則,說(shuō)明該用戶(hù)有權(quán)限,即顯示,否則影藏。影藏了是看不到鏈接地址,但是如果知道地址則可以通過(guò)地址直接訪問(wèn)。
(1)前臺(tái)判斷顯示與否。調(diào)用了自定義方法chackQ();
<if condition="chackQ('任務(wù)管理')"> <li><a href="{:U('taskinfo/dir')}" rel="external nofollow" >任務(wù)管理</a></li> </if>
(2) 具體對(duì)比操作。
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 "你沒(méi)有權(quán)限"; exit; } return $reset; }
至此,整個(gè)權(quán)限控制基本完成。
以上這篇thinkphp自定義權(quán)限管理之名稱(chēng)判斷方法就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
PHP聊天室簡(jiǎn)單實(shí)現(xiàn)方法詳解
這篇文章主要介紹了PHP聊天室簡(jiǎn)單實(shí)現(xiàn)方法,結(jié)合實(shí)例形式詳細(xì)分析了php聊天室相關(guān)數(shù)據(jù)庫(kù)操作與ajax交互等操作技巧,需要的朋友可以參考下2018-12-12PHP設(shè)計(jì)模式之抽象工廠模式實(shí)例分析
這篇文章主要介紹了PHP設(shè)計(jì)模式之抽象工廠模式,結(jié)合實(shí)例形式分析了php抽象工廠模式的概念、原理、使用方法及相關(guān)操作注意事項(xiàng),需要的朋友可以參考下2019-03-03PHP中大于2038年時(shí)間戳的問(wèn)題處理方案
這篇文章主要介紹了PHP中大于2038年時(shí)間戳的問(wèn)題處理方案,需要的朋友可以參考下2015-03-03php從右向左/從左向右截取字符串的實(shí)現(xiàn)方法
我先學(xué)的的asp,asp里截取字符串的函數(shù)很簡(jiǎn)單,也容易理解:left和right而php里從左向右截取和從右向左截取都是一個(gè)函數(shù):substr2011-11-11php根據(jù)用戶(hù)名和手機(jī)號(hào)查詢(xún)是否存在手機(jī)號(hào)碼
本文主要分享了php根據(jù)用戶(hù)名和手機(jī)號(hào)查詢(xún)是否存在手機(jī)號(hào)碼的代碼,具有很好的參考價(jià)值,下面跟著小編一起來(lái)看下吧2017-02-02PHP5中新增stdClass 內(nèi)部保留類(lèi)
stdClass類(lèi)是PHP的一個(gè)內(nèi)部保留類(lèi),初始時(shí)沒(méi)有成員變量也沒(méi)成員方法,所有的魔術(shù)方法都被設(shè)置為NULL,可以使用其傳遞變量參數(shù),但是沒(méi)有可以調(diào)用的方法。2011-06-06php實(shí)現(xiàn)網(wǎng)頁(yè)緩存的工具類(lèi)分享
本文給大家分享的是php實(shí)現(xiàn)網(wǎng)頁(yè)緩存的工具類(lèi)的代碼及使用方法,非常的實(shí)用,有需要的小伙伴可以參考下。2015-07-07