Yii权限分级式访问控制的实现

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('*'),   // *号标识所有用户包括注册的、没注册的、一般的、管理员级的         

),            

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('*'),              ),          );      }  

关于更多的访问规则的设定请参照官方文件    好了,现在要开始按照我们自己的需求设置适合自己的权限分配了。我们希望filter访问控制模式能更完美一点,按照常识,我们希望它能按照数据库里user表里不同级别用户,实行不同的授权,而不是用硬编码的形式控制。   回到demo blog,我先对数据库的tbl_user表做修改,在原来的基础上加上role一项。对原来的用户信息记录添加role的value为"管理员"或"一般用户"。  

然后依次执行以下3个步骤:  1. 创建组件WebUser,它是对CWebUser的扩展。 2. 修改config/main.php文件。  3.修改accessRules()。 

具体细节如下:  1.WebUser.php 组件代码:   

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'),           

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/11200.html