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


Posted in PHP onApril 01, 2017

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

一、建立数据库。

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

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

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

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

 

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

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

 

二、输出权限列表。

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

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

2、权限分配列表。

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

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

具体代码如下

<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>
循环示例图如:
thinkphp自定义权限管理之名称判断方法

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

PHP 相关文章推荐
[FAQ]PHP中的一些常识:类篇
Oct 09 PHP
优化php效率,提高php性能的一些方法
Mar 24 PHP
UCenter 批量添加用户的php代码
Jul 17 PHP
PHP中使用asort进行中文排序失效的问题处理
Aug 18 PHP
php中字符集转换iconv函数使用总结
Oct 11 PHP
PHP远程调试之XDEBUG
Dec 29 PHP
解析WordPress中控制用户登陆和判断用户登陆的PHP函数
Mar 01 PHP
基于PHP-FPM进程池探秘
Oct 17 PHP
PDO::quote讲解
Jan 29 PHP
laravel中数据显示方法(默认值和下拉option默认选中)
Oct 11 PHP
PHP接口类(interface)的定义、特点和应用示例
May 18 PHP
PHP底层运行机制与工作原理详解
Jul 31 PHP
浅谈ThinkPHP中initialize和construct的区别
Apr 01 #PHP
PHP房贷计算器实例代码,等额本息,等额本金
Apr 01 #PHP
PHP中file_put_contents追加和换行的实现方法
Apr 01 #PHP
centos下file_put_contents()无法写入文件的原因及解决方法
Apr 01 #PHP
php file_get_contents取文件中数组元素的方法
Apr 01 #PHP
PHP中Laravel 关联查询返回错误id的解决方法
Apr 01 #PHP
php获取ip及网址的简单方法(必看)
Apr 01 #PHP
You might like
php mysql_real_escape_string函数用法与实例教程
2013/09/30 PHP
ASP.NET中AJAX 调用实例代码
2012/05/03 Javascript
JS动态添加与删除select中的Option对象(示例代码)
2013/12/20 Javascript
JQuery结合CSS操作打印样式的方法
2013/12/24 Javascript
简介JavaScript中substring()方法的使用
2015/06/06 Javascript
JS实现响应鼠标点击动画渐变弹出层效果代码
2016/03/25 Javascript
node.js学习之base64编码解码
2016/10/21 Javascript
Three.js如何实现雾化效果示例代码
2017/09/27 Javascript
javascript数组定义的几种方法
2017/10/06 Javascript
基于JS实现html中placeholder属性提示文字效果示例
2018/04/19 Javascript
JavaScript实现表单注册、表单验证、运算符功能
2018/10/15 Javascript
vue实现从外部修改组件内部的变量的值
2020/07/30 Javascript
Vue+Java+Base64实现条码解析的示例
2020/09/23 Javascript
Python+Django在windows下的开发环境配置图解
2009/11/11 Python
Python 文件读写操作实例详解
2014/03/12 Python
Python实现远程调用MetaSploit的方法
2014/08/22 Python
Python用zip函数同时遍历多个迭代器示例详解
2016/11/14 Python
老生常谈进程线程协程那些事儿
2017/07/24 Python
python smtplib模块实现发送邮件带附件sendmail
2018/05/22 Python
详解python执行shell脚本创建用户及相关操作
2019/04/11 Python
python中的数据结构比较
2019/05/13 Python
python如何保证输入键入数字的方法
2019/08/23 Python
html5中 media(播放器)的api使用指南
2014/12/26 HTML / CSS
施华洛世奇德国官网:SWAROVSKI德国
2017/02/01 全球购物
Can a struct inherit from another class? (结构体能继承类吗)
2014/07/22 面试题
学生学习总结的自我评价
2013/10/22 职场文书
丧事主持词大全
2014/04/02 职场文书
法人授权委托书
2014/04/03 职场文书
安全生产知识竞赛活动总结
2014/07/07 职场文书
庆七一活动总结
2014/08/27 职场文书
财会专业大学生求职信
2014/09/26 职场文书
作弊检讨书
2015/01/27 职场文书
祝福语集锦:给妹妹结婚的祝福语
2019/12/18 职场文书
python自动化测试之Selenium详解
2022/03/13 Python
解决flex布局中子项目尺寸不受flex-shrink限制
2022/05/11 HTML / CSS
Zabbix对Kafka topic积压数据监控的解决方案
2022/07/07 Servers