《PHP實(shí)戰(zhàn):thinkphp自定義權(quán)限管理之名稱判斷方法》要點(diǎn):
本文介紹了PHP實(shí)戰(zhàn):thinkphp自定義權(quán)限管理之名稱判斷方法,希望對您有用。如果有疑問,可以聯(lián)系我們。
相關(guān)主題:thinkphp教程
PHP實(shí)戰(zhàn)權(quán)限管理,就是給不同的用戶分配不同的權(quán)限.當(dāng)用戶登錄或者操作時(shí)候進(jìn)行判斷,來阻止用戶進(jìn)行權(quán)限以外的操作.本次講的是當(dāng)用戶登錄一刻,只顯示權(quán)限開啟的內(nèi)容.
PHP實(shí)戰(zhàn)一、建立數(shù)據(jù)庫.
PHP實(shí)戰(zhàn)1、權(quán)限表funcla.來存儲錄入所有權(quán)限,也是避免因權(quán)限名稱修改了,權(quán)限失效的問題.
PHP實(shí)戰(zhàn)
PHP實(shí)戰(zhàn)
PHP實(shí)戰(zhàn)2、管理員表admin.主要存儲管理員用戶名等信息.
PHP實(shí)戰(zhàn)
PHP實(shí)戰(zhàn)?
PHP實(shí)戰(zhàn)3、管理員對應(yīng)權(quán)限表funadmin.主要存儲已開啟的管理員id與權(quán)限id.
PHP實(shí)戰(zhàn)
PHP實(shí)戰(zhàn)?
PHP實(shí)戰(zhàn)二、輸出權(quán)限列表.
PHP實(shí)戰(zhàn)1、通過管理員列表進(jìn)入權(quán)限分配.
PHP實(shí)戰(zhàn)
PHP實(shí)戰(zhàn)2、權(quán)限分配列表.
PHP實(shí)戰(zhàn)
PHP實(shí)戰(zhàn)關(guān)于權(quán)限分配列表,因?yàn)闄?quán)限板塊的不同,我們需要區(qū)別頂級分類與其子集.并且還需要顯示權(quán)限狀態(tài).在權(quán)限狀態(tài)判斷中也使用了一層循環(huán)判斷.代碼中采用了三層嵌套循環(huán)輸出.
PHP實(shí)戰(zhàn)具體代碼如下
PHP實(shí)戰(zhàn)
<div>分配管理員{$username}的權(quán)限</div>
<table width="100%" border="0" cellpadding="0" cellspacing="0" class="list_table mt10">
<tr>
<th>權(quán)限名稱</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>
PHP實(shí)戰(zhàn)3、具體控制器如下:
PHP實(shí)戰(zhàn)
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();
}
PHP實(shí)戰(zhàn)4、js.當(dāng)用戶權(quán)限發(fā)生改變時(shí),即觸發(fā)js提交json,向控制器傳遞數(shù)據(jù)參數(shù).
PHP實(shí)戰(zhàn)
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){
}
})
}
PHP實(shí)戰(zhàn)json傳遞的url地址用過頁面中實(shí)例化地址獲取.如:
PHP實(shí)戰(zhàn)
<script type="text/javascript">
var seturl="{:U("Admin/chanefun")}";
</script>
PHP實(shí)戰(zhàn)三、控制器獲取json的數(shù)據(jù)參數(shù),判斷權(quán)限的添加與修改.如果是添加,就向funadmin表中添加受理權(quán)限人id與要授權(quán)的權(quán)限id作為一條數(shù)據(jù).修改即刪除符合條件的一條數(shù)據(jù).同理.
PHP實(shí)戰(zhàn)
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();
}
PHP實(shí)戰(zhàn)四、真實(shí)權(quán)限判斷.前面都是為權(quán)限判斷做準(zhǔn)備的,現(xiàn)在才是真正的判斷,基本原理是把要判斷的權(quán)限名稱與當(dāng)前登錄用戶id拿到funadmin表中對比,如有發(fā)現(xiàn)則,說明該用戶有權(quán)限,即顯示,否則影藏.影藏了是看不到鏈接地址,但是如果知道地址則可以通過地址直接訪問.
PHP實(shí)戰(zhàn)(1)前臺判斷顯示與否.調(diào)用了自定義方法chackQ();
PHP實(shí)戰(zhàn)
<if condition="chackQ('任務(wù)管理')">
<li><a href="{:U('taskinfo/dir')}" rel="external nofollow" >任務(wù)管理</a></li>
</if>
PHP實(shí)戰(zhàn)(2) 具體對比操作.
PHP實(shí)戰(zhàn)
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 "你沒有權(quán)限";
exit;
}
return $reset;
}
PHP實(shí)戰(zhàn)至此,整個(gè)權(quán)限控制基本完成.
PHP實(shí)戰(zhàn)以上這篇thinkphp自定義權(quán)限管理之名稱判斷方法就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持維易PHP.
轉(zhuǎn)載請注明本頁網(wǎng)址:
http://www.snjht.com/jiaocheng/1285.html