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 相关文章推荐
在PHP中操作Excel实例代码
Apr 29 PHP
php继承的一个应用
Sep 06 PHP
php 转换字符串编码 iconv与mb_convert_encoding的区别说明
Nov 10 PHP
php漏洞之跨网站请求伪造与防止伪造方法
Aug 15 PHP
php中文乱码怎么办如何让浏览器自动识别utf-8
Jan 15 PHP
php输入流php://input使用浅析
Sep 02 PHP
MyEclipse常用配置图文教程
Sep 11 PHP
php简单实现无限分类树形列表的方法
Mar 27 PHP
php生成圆角图片的方法
Apr 07 PHP
ajax+php控制所有后台函数调用
Jul 15 PHP
PHP实现的一致性Hash算法详解【分布式算法】
Mar 31 PHP
PHP程序员学习使用Swoole的理由
Jun 24 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
.htaccess文件保护实例讲解
2011/02/06 PHP
Yii2实现同时搜索多个字段的方法
2016/08/10 PHP
thinkPHP简单实现多个子查询语句的方法
2016/12/05 PHP
Yii框架的布局文件实例分析
2019/09/04 PHP
php7下的filesize函数
2019/09/30 PHP
Laravel登录失败次数限制的实现方法
2020/08/26 PHP
JS实现浏览器菜单命令
2006/09/05 Javascript
用javascript实现计算两个日期的间隔天数
2007/08/14 Javascript
Prototype 工具函数 学习
2009/07/23 Javascript
js注意img图片的onerror事件的分析
2011/01/01 Javascript
javascript如何使用bind指定接收者
2014/05/04 Javascript
自定义jquery模态窗口插件无法在顶层窗口显示问题
2014/05/29 Javascript
javascript设计模式之解释器模式详解
2014/06/05 Javascript
jQuery基本过滤选择器用法示例
2016/09/09 Javascript
详解nodejs操作mongodb数据库封装DB类
2017/04/10 NodeJs
vue组件如何被其他项目引用
2017/04/13 Javascript
微信小程序 功能函数小结(手机号验证*、密码验证*、获取验证码*)
2017/12/08 Javascript
js实现一个简单的MVVM框架示例
2018/01/15 Javascript
深入解析微信小程序开发中遇到的几个小问题
2020/07/11 Javascript
Python简单连接MongoDB数据库的方法
2016/03/15 Python
Python进阶-函数默认参数(详解)
2017/05/18 Python
Linux CentOS7下安装python3 的方法
2018/01/21 Python
Python的iOS自动化打包实例代码
2018/11/22 Python
python linecache 处理固定格式文本数据的方法
2019/01/08 Python
PyQt5的安装配置过程,将ui文件转为py文件后显示窗口的实例
2019/06/19 Python
Python web如何在IIS发布应用过程解析
2020/05/27 Python
基于ccs3的timeline时间线实现方法
2020/04/30 HTML / CSS
Smashbox英国官网:美国知名彩妆品牌
2017/11/13 全球购物
KIKO MILANO俄罗斯官网:意大利领先的化妆品和护肤品品牌
2021/01/09 全球购物
航空学院求职信
2014/06/11 职场文书
2015年物流客服工作总结
2015/07/27 职场文书
2015大一新生军训感言
2015/08/01 职场文书
2016小学教师读书心得体会
2016/01/13 职场文书
2016年世界艾滋病日宣传活动总结
2016/04/01 职场文书
Pytorch 实现变量类型转换
2021/05/17 Python
Linux、ubuntu系统下查看显卡型号、显卡信息详解
2022/04/07 Servers