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 相关文章推荐
模拟xcopy的函数
Oct 09 PHP
php 静态变量与自定义常量的使用方法
Jan 26 PHP
深入了解 register_globals (附register_globals=off 网站打不开的解决方法)
Jun 27 PHP
php使浏览器直接下载pdf文件的方法
Nov 15 PHP
php实例分享之mysql数据备份
May 19 PHP
分享五个PHP7性能优化提升技巧
Dec 07 PHP
CodeIgniter辅助之第三方类库third_party用法分析
Jan 20 PHP
YII Framework框架教程之安全方案详解
Mar 14 PHP
thinkPHP5.0框架安装教程
Mar 25 PHP
详解PHP文件的自动加载(autoloading)
Feb 04 PHP
Laravel框架Blade模板简介及模板继承用法分析
Dec 03 PHP
tp5使用layui实现多个图片上传(带附件选择)的方法实例
Nov 17 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冒泡排序算法代码详细解读
2011/07/17 PHP
保存到桌面、设为桌面且带图标的PHP代码
2013/11/19 PHP
PHP文件上传判断file是否己选择上传文件的方法
2014/11/10 PHP
ThinkPHP进程计数类Process用法实例详解
2015/09/25 PHP
PHP折半(二分)查找算法实例分析
2018/05/12 PHP
jQuery+CSS 实现的超Sexy下拉菜单
2010/01/17 Javascript
js和jquery使按钮失效为不可用状态的方法
2014/01/26 Javascript
JS函数多个参数默认值指定方法分析
2016/11/28 Javascript
JavaScript实现的商品抢购倒计时功能示例
2017/04/17 Javascript
jQuery实现表单动态添加数据并提交的方法
2018/07/19 jQuery
Vue框架里使用Swiper的方法示例
2018/09/20 Javascript
详解Angular5/Angular6项目如何添加热更新(HMR)功能
2018/10/10 Javascript
JavaScript面试中常考的字符串操作方法大全(包含ES6)
2020/05/10 Javascript
jQuery 淡入/淡出效果函数用法分析
2020/05/19 jQuery
openlayers实现图标拖动获取坐标
2020/09/25 Javascript
js实现鼠标切换图片(无定时器)
2021/01/27 Javascript
[44:21]Ti4 循环赛第四日 附加赛NEWBEE vs LGD
2014/07/13 DOTA
python中的实例方法、静态方法、类方法、类变量和实例变量浅析
2014/04/26 Python
使用Python编写一个简单的tic-tac-toe游戏的教程
2015/04/16 Python
研究Python的ORM框架中的SQLAlchemy库的映射关系
2015/04/25 Python
Python cookbook(数据结构与算法)实现优先级队列的方法示例
2018/02/18 Python
python使用opencv驱动摄像头的方法
2018/08/03 Python
对Python中创建进程的两种方式以及进程池详解
2019/01/14 Python
python定时复制远程文件夹中所有文件
2019/04/30 Python
Python 最强编辑器详细使用指南(PyCharm )
2019/09/16 Python
python爬虫开发之使用python爬虫库requests,urllib与今日头条搜索功能爬取搜索内容实例
2020/03/10 Python
深入浅析Python 命令行模块 Click
2020/03/11 Python
新加坡最佳婴儿用品店:Mamahood.com.sg
2018/08/26 全球购物
怀旧收藏品和经典纪念品:Betty’s Attic
2018/08/29 全球购物
什么叫应用程序域?什么是受管制的代码?什么是强类型系统?什么是装箱和拆箱?
2016/08/13 面试题
大四自我鉴定范文
2013/10/06 职场文书
2014年党员自我评议总结
2014/09/23 职场文书
个人向公司借款协议书
2014/10/09 职场文书
2014小学教师年度考核工作总结
2014/12/03 职场文书
实习报告范文之电话客服岗位
2019/07/26 职场文书
mybatis 解决从列名到属性名的自动映射失败问题
2021/06/30 Java/Android