yii framework 提供了2套权限访问系统,一套是简单的filter(过滤器)模式,另一套是复杂全面的RBAC模式,我这里要讲的是第一套(因为我也刚刚学到这里)。如 果你有研究过YII官方的demo blog,一定知道,比如,由gii自动生成的user模块,自动附带了简单的filter权限分配功能,具体细节请参照blog手册的“用户验证”一章 节,以及yii官方指南的“验证和授权”一章节。(注意,我这里所指的模块,只是我个人对与user有关的文件的统称,与yii文件系统的模块 (module)含义不同。) 关于权限分配的文件大多在controllers里,比如打开UserController.php文件你会看到2个类函数。 <div class="codetitle"><a style="CURSOR: pointer" data="52392" class="copybut" id="copybut52392" onclick="doCopy('code52392')"> 代码如下:<div class="codebody" id="code52392"> 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('@'),// @号指所有注册的用户 ),// 只允许用户名是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为"管理员"或"一般用户"。
<FONT style="COLOR: #0000ff">然后依次执行以下3个步骤:
<FONT style="COLOR: #ff0000">1. 创建组件WebUser,它是对CWebUser的扩展。 2. 修改config/main.php文件。 3.修改accessRules()。
具体细节如下:
1.WebUser.php 组件代码: <div class="codetitle"><a style="CURSOR: pointer" data="44106" class="copybut" id="copybut44106" onclick="doCopy('code44106')"> 代码如下:<div class="codebody" id="code44106">
<?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; } } ?>
2.在config/main.php找到如下代码,添加标红色的代码。 <div class="codetitle"><a style="CURSOR: pointer" data="22079" class="copybut" id="copybut22079" onclick="doCopy('code22079')"> 代码如下:<div class="codebody" id="code22079"> 'components'=>array( 'user'=>array( // enable cookie-based authentication 'allowAutoLogin'=>true, 'class'=>'WebUser',
3.找到需要更改权限的controller类,对accessRules()函数做修改,比如对前文的accessRules()函数做如下修改: <div class="codetitle"><a style="CURSOR: pointer" data="61600" class="copybut" id="copybut61600" onclick="doCopy('code61600')"> 代码如下:<div class="codebody" id="code61600"> public function accessRules() //这里就是访问规则的设置。 { return array( array('allow',//*号标识所有用户包括注册的、没注册的、一般的、管理员级的 ), 'expression'=>'yii::app()->user->isAdmin()', //这样只有标识为“管理员”的用户才能访问admin,delete动作 ), array('deny', );
工作完成!
(编辑:李大同)
【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!
|