当前位置: 网学 > 编程文档 > PHP > 正文

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

来源:Http://myeducs.cn 联系QQ:点击这里给我发消息 作者: 用户投稿 来源: 网络 发布时间: 13/06/18

网学网为需要PHP的朋友们搜集整理了深入解析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 深入解析yii权限分级式访问控制的实现(非RBAC法)_网学
浏览:
版权所有 QQ:3710167 邮箱:3710167@qq.com 网学网 [Myeducs.cn] 您电脑的分辨率是 像素
Copyright 2008-2015 myeducs.Cn www.myeducs.Cn All Rights Reserved
湘ICP备09003080号
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

网学推荐

免费论文

原创论文

浏览:
设为首页 | 加入收藏 | 论文首页 | 论文专题 | 设计下载 | 网学软件 | 论文模板 | 论文资源 | 程序设计 | 关于网学 | 站内搜索 | 网学留言 | 友情链接 | 资料中心
版权所有 QQ:3710167 邮箱:3710167@qq.com 网学网 [Myeducs.cn] 您电脑的分辨率是 像素
Copyright 2008-2015 myeducs.Cn www.myeducs.Cn All Rights Reserved
湘ICP备09003080号