糖尿病康复,内容丰富有趣,生活中的好帮手!
糖尿病康复 > 深入解析yii权限分级式访问控制的实现(非RBAC法)

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

时间:2019-01-28 00:53:56

相关推荐

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

php教程|php手册

yii,权限分级式,访问控制

php教程-php手册

多媒体记事本源码,下载网页设计与布局vscode,Ubuntu arm 源,堡垒机怎么访问tomcat,c 配置sqlite,手机web网页设计,ftp不能连接服务器,wordpess 缩略图插件,前端框架组件插件,爬虫详细教程,php调用python,seo刷排名软件,springboot怎么调日志,电子商城网站模板,网页头部出现空白,电子商城模板下载,织梦后台 检测,帝国cms新页面空白,java 图书管理系统源代码,bp算法程序matlablzw

本篇文章是对yii权限分级式访问控制的实现方法进行了详细的分析介绍,需要的朋友参考下

测试题小程序源码,ubuntu如何节约能耗,tomcat连接数据库方式,蚌埠爬虫ip厂,云服务器支持php吗,优化seo教学lzw

9酷音乐源码,vscode 跟踪代码,电脑ubuntu分配率,tomcat页面很慢,sqlite 小数点,闲鱼搜索栏插件,前端框架最新排名,抖音爬虫加密,php 获取上传的文件,百度SEO软件挣钱,手机网站js源码下载,手机商店 网页模版,织梦简单会员中心模板,jquery使透明背景层覆盖整个页面,房产中介管理系统数据库,开源跑腿小程序lzw

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 组件代码:

复制代码 代码如下:

<?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(‘*’),

),

);

工作完成!

如果觉得《深入解析yii权限分级式访问控制的实现(非RBAC法)》对你有帮助,请点赞、收藏,并留下你的观点哦!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。