加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

thinkphp自定义权限管理之名称判断方法

发布时间:2020-12-14 14:08:01 所属栏目:大数据 来源:网络整理
导读:权限管理,就是给不同的用户分配不同的权限。当用户登录或者操作时候进行判断,来阻止用户进行权限以外的操作。本次讲的是当用户登录一刻,只显示权限开启的内容。 一、建立数据库。 1、权限表funcla。来存储录入所有权限,也是避免因权限名称修改了,权限失

权限管理,就是给不同的用户分配不同的权限。当用户登录或者操作时候进行判断,来阻止用户进行权限以外的操作。本次讲的是当用户登录一刻,只显示权限开启的内容。

一、建立数据库。

1、权限表funcla。来存储录入所有权限,也是避免因权限名称修改了,权限失效的问题。

      

    

2、管理员表admin。主要存储管理员用户名等信息。

3、管理员对应权限表funadmin。主要存储已开启的管理员id与权限id。

二、输出权限列表。

1、通过管理员列表进入权限分配。

2、权限分配列表。

关于权限分配列表,因为权限板块的不同,我们需要区别顶级分类与其子集。并且还需要显示权限状态。在权限状态判断中也使用了一层循环判断。代码中采用了三层嵌套循环输出。

具体代码如下

分配管理员{$username}的权限
权限名称
</tr&gt;
<volist name="funcla" id="v" key="j"&gt;
   <tr class="tr"&gt;
     <td&gt;{$v.claname}</td&gt;
     <td&gt;<input <volist name="funadmin" id="d"&gt;<if condition="$d['funclaid'] eq $v['id']"&gt;checked</if></volist> type="checkbox" id="{$v.id}" name="{$userid}" onchange="return setfun(this,seturl)" /></td&gt;
   </tr&gt;
  <volist name="fun" id="vo"&gt;
    <if condition="$vo['clapid'] eq $v['id']"&gt;
      <tr class="tr"&gt;
        <td style="padding-left: 40px;" >{$vo.claname}</td&gt;

        <td&gt;

          <input <volist name="funadmin" id="d"&gt;<if condition="$d['funclaid'] eq $vo['id']"&gt;checked</if></volist> type="checkbox" id="{$vo.id}" name="{$userid}" onchange="return setfun(this,seturl)" />

        </td&gt;

      </tr&gt;
    </if>
  </volist>
</volist>

</table>

循环示例图如:

3、具体控制器如下:

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,向控制器传递数据参数。

})
}

json传递的url地址用过页面中实例化地址获取。如:

三、控制器获取json的数据参数,判断权限的添加与修改。如果是添加,就向funadmin表中添加受理权限人id与要授权的权限id作为一条数据。修改即删除符合条件的一条数据。同理。

$m=M('funadmin'); $where['funclaid']=I('post.id','int'); $where['adminid']=I('post.uid','int'); $type=I('post.type','int'); if(empty($type)){ $oid=$m->where($where)->getfield('id'); $m->delete($oid); return; } $m->data($where)->add();

}

四、真实权限判断。前面都是为权限判断做准备的,现在才是真正的判断,基本原理是把要判断的权限名称与当前登录用户id拿到funadmin表中对比,如有发现则,说明该用户有权限,即显示,否则影藏。影藏了是看不到链接地址,但是如果知道地址则可以通过地址直接访问。

(1)前台判断显示与否。调用了自定义方法chackQ();

任务管理

(2) 具体对比操作。

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自定义权限管理之名称判断方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持编程之家。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

状态