深入解析yii权限分级式访问控制的实现(非RBAC法)


Posted in PHP onJune 13, 2013

yii framework 提供了2套权限访问系统,一套是简单的filter(过滤器)模式,另一套是复杂全面的RBAC模式,我这里要讲的是第一套(因为我也刚刚学到这里)。如 果你有研究过YII官方的demo blog,一定知道,比如,由gii自动生成的user模块,自动附带了简单的filter权限分配功能,具体细节请参照blog手册的“用户验证”一章 节,以及yii官方指南的“验证和授权”一章节。(注意,我这里所指的模块,只是我个人对与user有关的文件的统称,与yii文件系统的模块 (module)含义不同。)
关于权限分配的文件大多在controllers里,比如打开UserController.php文件你会看到2个类函数。

public function filters() 
     { 
      return array( 
       'accessControl',               // 实现CRUD操作的访问控制。 
       'postOnly + delete', 
         ); 
     }  public function accessRules()              //这里就是访问规则的设置。 
     { 
      return array( 
         array('allow',              // 允许所有用户执行index,view动作。 
           'actions'=>array('index','view'), 
           'users'=>array('*'), <span></span>           
           ),                    
         array('allow',             // 只允许经过验证的用户执行create, update动作。 
            'actions'=>array('create','update'), 
            'users'=>array('@'),       // @号指所有注册的用户 
             ), 
         array('allow',             // 只允许用户名是admin的用户执行admin,delete动作 
             'actions'=>array('admin','delete'), 
             'users'=>array('admin'), 
             ),                   //admin就是指用户名是admin的用户,以硬编码的形式分配用户权限。 
             array('deny',           // 拒绝所有的访问。 
             'users'=>array('*'), 
             ), 
         ); 
     }

关于更多的访问规则的设定请参照官方文件http://www.yiiframework.com/doc/api/1.1/CAccessControlFilter
好了,现在要开始按照我们自己的需求设置适合自己的权限分配了。我们希望filter访问控制模式能更完美一点,按照常识,我们希望它能按照数据库里user表里不同级别用户,实行不同的授权,而不是用硬编码的形式控制。

回到demo blog,我先对数据库的tbl_user表做修改,在原来的基础上加上role一项。对原来的用户信息记录添加role的value为"管理员"或"一般用户"。
然后依次执行以下3个步骤:
1. 创建组件WebUser,它是对CWebUser的扩展。
2. 修改config/main.php文件。
3.修改accessRules()。
具体细节如下:
1.WebUser.php 组件代码:

<strong><?php  // this file must be stored in: 
 // protected/components/WebUser.php 
 class WebUser extends CWebUser { 
   // Store model to not repeat query. 
   private $_model; 
   // Return first name. 
   // access it by Yii::app()->user->first_name 
   function getFirst_Name(){ 
     $user = $this->loadUser(Yii::app()->user->id); 
     return $user->first_name; 
   } 
   // This is a function that checks the field 'role' 
   // in the User model to be equal to 1, that means it's admin 
   // access it by Yii::app()->user->isAdmin() 
   function isAdmin(){ 
     $user = $this->loadUser(Yii::app()->user->id); 
     if ($user==null) 
         return 0; 
     else 
         return $user->role == "管理员"; 
   } 
   // Load user model. 
   protected function loadUser($id=null) 
     { 
         if($this->_model===null) 
         { 
             if($id!==null) 
                 $this->_model=User::model()->findByPk($id); 
         } 
         return $this->_model; 
     } 
 } 
 ?></strong>

2.在config/main.php找到如下代码,添加标红色的代码。
   'components'=>array(
        'user'=>array(
            // enable cookie-based authentication
            'allowAutoLogin'=>true,
             'class'=>'WebUser',
        ),

3.找到需要更改权限的controller类,对accessRules()函数做修改,比如对前文的accessRules()函数做如下修改:
public function accessRules()  //这里就是访问规则的设置。     { 
     return array( 
         array('allow',                     // 允许所有用户执行index,view动作。 
             'actions'=>array('index','view'), 
             'users'=>array('*'),         //*号标识所有用户包括注册的、没注册的、一般的、管理员级的 
         ), 
         array('allow',                      // 只允许经过验证的用户执行create, update动作。 
             'actions'=>array('create','update'), 
             'users'=>array('@'),       // @号指所有注册的用户 
         ), 
         array('allow',                     // 只允许用户名是admin的用户执行admin,delete动作 
             'actions'=>array('admin','delete'), 
             'expression'=>'yii::app()->user->isAdmin()', 
             //这样只有标识为“管理员”的用户才能访问admin,delete动作 
         ), 
         array('deny',  // 拒绝所有的访问。 
             'users'=>array('*'), 
         ), 
     );

工作完成!
PHP 相关文章推荐
php读取图片内容并输出到浏览器的实现代码
Aug 08 PHP
单台服务器的PHP进程之间实现共享内存的方法
Jun 13 PHP
PHP函数in_array()使用详解
Aug 20 PHP
浅析PHP中strlen和mb_strlen的区别
Aug 31 PHP
跟我学Laravel之视图 &amp; Response
Oct 15 PHP
php检测数组长度函数sizeof与count用法
Nov 17 PHP
PHP+APACHE实现网址伪静态
Feb 22 PHP
php输入数据统一类实例
Feb 23 PHP
日常整理PHP中简单的图形处理(经典)
Oct 26 PHP
PHP多维数组指定多字段排序的示例代码
May 16 PHP
php实现微信公众号企业转账功能
Oct 01 PHP
php实现记事本案例
Oct 20 PHP
PHP 基于Yii框架中使用smarty模板的方法详解
Jun 13 #PHP
关于PHP二进制流 逐bit的低位在前算法(详解)
Jun 13 #PHP
php读取二进制流(C语言结构体struct数据文件)的深入解析
Jun 13 #PHP
基于PHP Socket配置以及实例的详细介绍
Jun 13 #PHP
深入php socket的讲解与实例分析
Jun 13 #PHP
PHP数据类型的总结分析
Jun 13 #PHP
如何用C语言编写PHP扩展的详解
Jun 13 #PHP
You might like
php中计算程序运行时间的类代码
2012/11/03 PHP
浅谈php7的重大新特性
2015/10/23 PHP
Redis构建分布式锁
2017/03/28 PHP
Js的MessageBox
2006/12/03 Javascript
javascritp实现input输入框相关限制用法
2007/06/29 Javascript
JavaScript快速检测浏览器对CSS3特性的支持情况
2012/09/26 Javascript
jquery移动节点实例
2015/01/14 Javascript
jquery实现textarea输入框限制字数的方法
2015/01/15 Javascript
浅谈jQuery中height与width
2015/07/06 Javascript
jQuery平滑旋转幻灯片特效代码分享
2015/09/07 Javascript
JS读取XML文件数据并以table形式显示数据的方法(兼容IE与火狐)
2016/06/02 Javascript
8 行 Node.js 代码实现代理服务器
2016/12/05 Javascript
JavaScript基础心法 深浅拷贝(浅拷贝和深拷贝)
2018/03/05 Javascript
js实现点击按钮复制文本功能
2020/07/20 Javascript
使用layer模态框给新页面传值的方法
2019/09/27 Javascript
[04:31]2016国际邀请赛中国区预选赛妖精采访
2016/06/27 DOTA
python根据文件大小打log日志
2014/10/09 Python
python文件读写操作与linux shell变量命令交互执行的方法
2015/01/14 Python
连接Python程序与MySQL的教程
2015/04/29 Python
Python中使用多进程来实现并行处理的方法小结
2017/08/09 Python
Python文本统计功能之西游记用字统计操作示例
2018/05/07 Python
python 使用re.search()筛选后 选取部分结果的方法
2018/11/28 Python
Python Selenium异常处理的实例分析
2021/02/28 Python
CSS3 border-radius圆角的实现方法及用法详解
2020/09/14 HTML / CSS
基于Html5实现的react拖拽排序组件示例
2018/08/13 HTML / CSS
Chemist Warehouse官方海外旗舰店:澳洲第一连锁大药房
2017/08/25 全球购物
加拿大时尚潮流大码女装购物网站:Addition Elle
2018/04/02 全球购物
Glamest意大利:女性在线奢侈品零售店
2019/04/28 全球购物
电气工程师岗位职责
2014/01/01 职场文书
文秘人员工作职责
2014/01/31 职场文书
2014年党务公开实施方案
2014/02/27 职场文书
2014年社会实践活动总结范文
2014/04/29 职场文书
2014房屋登记授权委托书
2014/10/13 职场文书
音乐教师求职信范文
2015/03/20 职场文书
pytorch中[..., 0]的用法说明
2021/05/20 Python
vue.js 使用原生js实现轮播图
2022/04/26 Vue.js