PHP-权限控制类(转)
<?php
/**
* 权限控制类
*/ class include_purview
{
/**
* 类的唯一实例
*/
private static $instance; /**
* 权限常量
*/
const SELECT = 0x1; //查询
const CREATE = 0x2; //添加
const EDIT = 0x4; //修改
const DELETE = 0x8; //删除 /**
* 角色
*/
private $annoy = ''; //匿名用户
private $user = ''; //注册用户
private $admin = ''; //管理用户
private $usertype = 'annoy';
private $hashtable = array(1=>'查询',2=>'添加',4=>'修改',8=>'删除'); /**
*
*/
public function __set($name,$value)
{
if ($name == 'usertype')
{
if ($value != '')
{
$this->usertype = $value;
}
}
} /**
* 构造函数 给角色赋予权限
*/
private function __construct()
{
$this->annoy = self::SELECT;
$this->user = self::SELECT | self::CREATE;
$this->admin = self::SELECT | self::CREATE | self::EDIT | self::DELETE;
} /**
* 获取类的唯一实例
*/
public static function getInstance()
{
if (self::$instance === null){
self::$instance = new include_purview();
}
return self::$instance;
} /**
* 检查权限
*
* @param $usertype 角色
* @param $purview 权限
*/
public function check($purview)
{
if ($this->{$this->usertype} & $purview)
{
return true;
}
return false;
} /**
* 给角色加权限
*/
public function addPur($purview)
{
$this->{$this->usertype} |= $purview;
} /**
* 给角色减权限
*/
public function delPur($purview)
{
$this->{$this->usertype} ^= $purview;
} /**
* 返回角色拥有的权限
*/
public function getPur()
{
$arr = array();
foreach ($this->hashtable as $k => $v)
{
if ($k & $this->{$this->usertype})
{
$arr[] = $v;
}
}
return $arr;
}
}
调用示例
PHP代码
/**
* 示例
*/
//在session中读用户组
@session_start();
$_SESSION['role'] = 'user'; //获取权限类的实例
$pruview = include_purview::getInstance();
//设置角色
$pruview->usertype = $_SESSION['role'];
//获取该角色拥有的权限
$arr = $pruview->getpur();
echo '该用户的权限有:'.join(',',$arr)."\n";
//判断执行的操作是否有权限
if (true === $pruview->check(include_purview::CREATE ))
{
create(); //要执行的操作
}
else
{
exit('您没有权限!');
}
//去掉用户的添加权限
$pruview->delPur(include_purview::CREATE );
$arr = $pruview->getpur();
echo '该用户的权限有:'.join(',',$arr)."\n";
//执行添加操作
if (true === $pruview->check(include_purview::CREATE ))
{
create(); //要执行的操作
}
else
{
echo '您没有权限!'."\n";
}
//加上用户的添加权限
$pruview->addPur(include_purview::CREATE );
$arr = $pruview->getpur();
echo '该用户的权限有:'.join(',',$arr)."\n";
//执行添加操作
if (true === $pruview->check(include_purview::CREATE ))
{
create(); //要执行的操作
}
else
{
exit('您没有权限!');
} //具体的操作
function create()
{
echo '执行了添加操作'."\n";
}
PHP-权限控制类(转)的更多相关文章
- 尝试asp.net mvc 基于controller action 方式权限控制方案可行性
微软在推出mvc框架不久,短短几年里,版本更新之快,真是大快人心,微软在这种优秀的框架上做了大量的精力投入,是值得赞同的,毕竟程序员驾驭在这种框架上,能够强力的精化代码,代码层次也更加优雅,扩展较为方 ...
- Java成员的访问权限控制
Java中的访问权限控制包含两个部分: 类的访问权限控制 类成员的访问权限控制 对类来说,访问权限控制修饰符可以是public或者无修饰符(默认的包访问权限): 对于类成员来说,访问权限控制修饰符可以 ...
- PHP-权限控制类
http://blog.csdn.net/painsonline/article/details/7183679 <?php /** * 权限控制类 */ class include_purvi ...
- Hive权限控制和超级管理员的实现
Hive权限控制 Hive权限机制: Hive从0.10可以通过元数据控制权限.但是Hive的权限控制并不是完全安全的.基本的授权方案的目的是防止用户不小心做了不合适的事情. 先决条件: 为了使用Hi ...
- 尝试asp.net mvc 基于controller action 方式权限控制方案可行性(转载)
微软在推出mvc框架不久,短短几年里,版本更新之快,真是大快人心,微软在这种优秀的框架上做了大量的精力投入,是值得赞同的,毕竟程序员驾驭在这种框架上,能够强力的精化代码,代码层次也更加优雅,扩展较为方 ...
- **CodeIgniter通过hook的方式实现简单的权限控制
根据自己的实际情况,需要两个文件,一个是权限控制类,Acl,另外一个是权限配置的文件acl.php放在了config这个目录下. Acl这个类放在了application/hook/acl.php.通 ...
- React+DvaJS 之 hook 路由权限控制
博客 学院 下载 GitChat TinyMind 论坛 APP 问答 商城 VIP 活动 招聘 ITeye 写博客 发Chat 登录注册 原 React+DvaJS 之 hook 路由权限控制 20 ...
- Hive 文件格式 & Hive操作(外部表、内部表、区、桶、视图、索引、join用法、内置操作符与函数、复合类型、用户自定义函数UDF、查询优化和权限控制)
本博文的主要内容如下: Hive文件存储格式 Hive 操作之表操作:创建外.内部表 Hive操作之表操作:表查询 Hive操作之表操作:数据加载 Hive操作之表操作:插入单表.插入多表 Hive语 ...
- Hive 基本语法操练(六):Hive 的权限控制
Hive 的权限控制 Hive从0.10可以通过元数据控制权限.但是Hive的权限控制并不是完全安全的.基本的授权方案的目的是防止用户不小心做了不合适的事情. 为了使用Hive的授权机制,有两个参数必 ...
随机推荐
- GNU make 指南
http://docs.huihoo.com/gnu/linux/gmake.html GNU make 指南 翻译: 哈少 译者按: 本文是一篇介绍 GNU Make 的文章,读完后读者应该基本掌握 ...
- hihoCoder - 1082 - 然而沼跃鱼早就看穿了一切 (字符串处理!!)
#1082 : 然而沼跃鱼早就看穿了一切 时间限制:1000ms 单点时限:1000ms 内存限制:256MB 描写叙述 fjxmlhx每天都在被沼跃鱼刷屏,因此他急切的找到了你希望你写一个程序屏蔽全 ...
- STL源码剖析——hashtable
二叉搜索树具有对数时间的搜索复杂度,但是这样的复杂度是再输入数据有足够的随机性的假设上哈希表在插入删除搜索操作上也具有常数时间的表现,而且这种表现是以统计为基础,不需要依赖输入元素的随机性 hasht ...
- linux清空文件方法
1.以下方法,清除后,文件大小为0 2.以下方法,清除后,文件大小为1 多了一个结束字符
- iOS:CoreData数据库的使用二(创建多个数据库表,表之间有对应关系)
CoreData数据库框架是一个封装性好,功能强大数据库,它底层使用的还是sqlite数据库,不过苹果公司在其基础上,为其封装新和安全性的维护上做了大量的处理,例如对一些事物做了详细的操作,如读脏数据 ...
- 漏洞预警 | ECShop全系列版本远程代码执行高危漏洞
2018年9月1日,阿里云态势感知发布预警,近日利用ECShop全系列版本的远程代码执行漏洞进行批量化攻击量呈上升趋势.该漏洞利用简单且危害较大,黑客可通过WEB攻击直接获得服务器权限. 漏洞原理 该 ...
- exchange 升级顺序导致的邮件被发不出的问题?
最近在做一个项目POC,准备升级过程目前的2007 环境到exchange 2010,由于客户环境是exchange 2007 sp1 不满足升级的基本条件,我们必须将exchange 2007 sp ...
- 倾斜摄影三维建模软件photoscan教程 [转]
PhotoScan是一款基于影响自动生成高质量三维模型的优秀软件,这对于3D建模需求来说实在是一把利器. PhotoScan无需设置初始值,无须相机检校,它根据最新的多视图三维重建技术,可对任意照片进 ...
- cocos2d-x游戏开发 跑酷(八) 对象管理 碰撞检測
对象管理类的原理是这种: ObjectManager类是一个单例类,全局仅仅有一个对象实例存在.初始化的时候创建两个数组CCArray来保存金币和岩石.为什么要保存,由于在地图重载的时候.要销毁看不见 ...
- MySQL服务器安装完之后如何调节性能
原文作者: Peter Zaitsev原文来源: http://www.mysqlperformanceblog.com/2006/09/29/what-to-tune-in-mysql-server ...