侧边栏壁纸
博主头像
落叶人生博主等级

走进秋风,寻找秋天的落叶

  • 累计撰写 130562 篇文章
  • 累计创建 28 个标签
  • 累计收到 9 条评论
标签搜索

目 录CONTENT

文章目录

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

2022-06-16 星期四 / 0 评论 / 0 点赞 / 84 阅读 / 6213 字

主要参考资料来源:yii官网http://www.yiiframework.com/wiki/60/ 我只是做了小小的完善。 yii framework 提供了2套权限访问系统,一套是简单的fil

主要参考资料来源:yii官网http://www.yiiframework.com/wiki/60/  我只是做了小小的完善。

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


关于更多的访问规则的设定请参照官方文件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 组件代码:

<?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找到如下代码,添加标红色的代码。

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

   


工作完成!

. .
 
. .

广告 广告

评论区