gpt4 book ai didi

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

转载 作者:qq735679552 更新时间:2022-09-29 22:32:09 27 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章深入解析yii权限分级式访问控制的实现(非RBAC法)由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

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

工作完成! 。

最后此篇关于深入解析yii权限分级式访问控制的实现(非RBAC法)的文章就讲到这里了,如果你想了解更多关于深入解析yii权限分级式访问控制的实现(非RBAC法)的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com