http://blog.csdn.net/painsonline/article/details/7183679

  1. <?php
  2. /**
  3. * 权限控制类
  4. */
  5. class include_purview
  6. {
  7. /**
  8. * 类的唯一实例
  9. */
  10. private static $instance;
  11. /**
  12. * 权限常量
  13. */
  14. const SELECT = 0x1; //查询
  15. const CREATE = 0x2; //添加
  16. const EDIT    = 0x4; //修改
  17. const DELETE = 0x8; //删除
  18. /**
  19. * 角色
  20. */
  21. private $annoy = ''; //匿名用户
  22. private $user   = ''; //注册用户
  23. private $admin = ''; //管理用户
  24. private $usertype = 'annoy';
  25. private $hashtable = array(1=>'查询',2=>'添加',4=>'修改',8=>'删除');
  26. /**
  27. *
  28. */
  29. public function __set($name,$value)
  30. {
  31. if ($name == 'usertype')
  32. {
  33. if ($value != '')
  34. {
  35. $this->usertype = $value;
  36. }
  37. }
  38. }
  39. /**
  40. * 构造函数 给角色赋予权限
  41. */
  42. private function __construct()
  43. {
  44. $this->annoy = self::SELECT;
  45. $this->user = self::SELECT | self::CREATE;
  46. $this->admin = self::SELECT | self::CREATE | self::EDIT | self::DELETE;
  47. }
  48. /**
  49. * 获取类的唯一实例
  50. */
  51. public static function getInstance()
  52. {
  53. if (self::$instance === null){
  54. self::$instance = new include_purview();
  55. }
  56. return self::$instance;
  57. }
  58. /**
  59. * 检查权限
  60. *
  61. * @param $usertype 角色
  62. * @param $purview 权限
  63. */
  64. public function check($purview)
  65. {
  66. if ($this->{$this->usertype} & $purview)
  67. {
  68. return true;
  69. }
  70. return false;
  71. }
  72. /**
  73. * 给角色加权限
  74. */
  75. public function addPur($purview)
  76. {
  77. $this->{$this->usertype} |= $purview;
  78. }
  79. /**
  80. * 给角色减权限
  81. */
  82. public function delPur($purview)
  83. {
  84. $this->{$this->usertype} ^= $purview;
  85. }
  86. /**
  87. * 返回角色拥有的权限
  88. */
  89. public function getPur()
  90. {
  91. $arr = array();
  92. foreach ($this->hashtable as $k => $v)
  93. {
  94. if ($k & $this->{$this->usertype})
  95. {
  96. $arr[] = $v;
  97. }
  98. }
  99. return $arr;
  100. }
  101. }

调用示例

PHP代码
  1. /**
  2. * 示例
  3. */
  4. //在session中读用户组
  5. @session_start();
  6. $_SESSION['role'] = 'user';
  7. //获取权限类的实例
  8. $pruview = include_purview::getInstance();
  9. //设置角色
  10. $pruview->usertype = $_SESSION['role'];
  11. //获取该角色拥有的权限
  12. $arr = $pruview->getpur();
  13. echo '该用户的权限有:'.join(',',$arr)."\n";
  14. //判断执行的操作是否有权限
  15. if (true === $pruview->check(include_purview::CREATE ))
  16. {
  17. create(); //要执行的操作
  18. }
  19. else
  20. {
  21. exit('您没有权限!');
  22. }
  23. //去掉用户的添加权限
  24. $pruview->delPur(include_purview::CREATE );
  25. $arr = $pruview->getpur();
  26. echo '该用户的权限有:'.join(',',$arr)."\n";
  27. //执行添加操作
  28. if (true === $pruview->check(include_purview::CREATE ))
  29. {
  30. create(); //要执行的操作
  31. }
  32. else
  33. {
  34. echo '您没有权限!'."\n";
  35. }
  36. //加上用户的添加权限
  37. $pruview->addPur(include_purview::CREATE );
  38. $arr = $pruview->getpur();
  39. echo '该用户的权限有:'.join(',',$arr)."\n";
  40. //执行添加操作
  41. if (true === $pruview->check(include_purview::CREATE ))
  42. {
  43. create(); //要执行的操作
  44. }
  45. else
  46. {
  47. exit('您没有权限!');
  48. }
  49. //具体的操作
  50. function create()
  51. {
  52. echo '执行了添加操作'."\n";
  53. }

PHP-权限控制类的更多相关文章

  1. 尝试asp.net mvc 基于controller action 方式权限控制方案可行性

    微软在推出mvc框架不久,短短几年里,版本更新之快,真是大快人心,微软在这种优秀的框架上做了大量的精力投入,是值得赞同的,毕竟程序员驾驭在这种框架上,能够强力的精化代码,代码层次也更加优雅,扩展较为方 ...

  2. Java成员的访问权限控制

    Java中的访问权限控制包含两个部分: 类的访问权限控制 类成员的访问权限控制 对类来说,访问权限控制修饰符可以是public或者无修饰符(默认的包访问权限): 对于类成员来说,访问权限控制修饰符可以 ...

  3. Hive权限控制和超级管理员的实现

    Hive权限控制 Hive权限机制: Hive从0.10可以通过元数据控制权限.但是Hive的权限控制并不是完全安全的.基本的授权方案的目的是防止用户不小心做了不合适的事情. 先决条件: 为了使用Hi ...

  4. 尝试asp.net mvc 基于controller action 方式权限控制方案可行性(转载)

    微软在推出mvc框架不久,短短几年里,版本更新之快,真是大快人心,微软在这种优秀的框架上做了大量的精力投入,是值得赞同的,毕竟程序员驾驭在这种框架上,能够强力的精化代码,代码层次也更加优雅,扩展较为方 ...

  5. **CodeIgniter通过hook的方式实现简单的权限控制

    根据自己的实际情况,需要两个文件,一个是权限控制类,Acl,另外一个是权限配置的文件acl.php放在了config这个目录下. Acl这个类放在了application/hook/acl.php.通 ...

  6. PHP-权限控制类(转)

    <?php /** * 权限控制类 */ class include_purview { /** * 类的唯一实例 */ private static $instance; /** * 权限常量 ...

  7. React+DvaJS 之 hook 路由权限控制

    博客 学院 下载 GitChat TinyMind 论坛 APP 问答 商城 VIP 活动 招聘 ITeye 写博客 发Chat 登录注册 原 React+DvaJS 之 hook 路由权限控制 20 ...

  8. Hive 文件格式 & Hive操作(外部表、内部表、区、桶、视图、索引、join用法、内置操作符与函数、复合类型、用户自定义函数UDF、查询优化和权限控制)

    本博文的主要内容如下: Hive文件存储格式 Hive 操作之表操作:创建外.内部表 Hive操作之表操作:表查询 Hive操作之表操作:数据加载 Hive操作之表操作:插入单表.插入多表 Hive语 ...

  9. Hive 基本语法操练(六):Hive 的权限控制

    Hive 的权限控制 Hive从0.10可以通过元数据控制权限.但是Hive的权限控制并不是完全安全的.基本的授权方案的目的是防止用户不小心做了不合适的事情. 为了使用Hive的授权机制,有两个参数必 ...

随机推荐

  1. 4.5你太黑了,不带这么玩TypeForwardedTo的

    话说最近好不容易把framework 4.0的metadata信息都能全部抽出了,结果换4.5挂了...framework那帮人在4.5里面用了些什么诡异的玩意? 结果一看4.5的部分field用了t ...

  2. Linux配置无线网卡驱动实现无线上网

    本机装Linux,需要配置的无线驱动.一般Ubuntu都集成无线驱动,基本上无线可以直接使用! 01.查看无线网卡的型号 [root@Mr-zhao software]# lspci    | gre ...

  3. linux基础-第十七单元 Samba服务

    Samba的功能 Samba的安装 Samba服务的启动.停止.重启 Samba服务的配置 Samba服务的主配置文件 samba服务器配置实例 Samba客户端设置 windows客户端 Linux ...

  4. HIbernate的脏数据检测和延缓加载

    脏数据监测: 在一个事务中,加载的数据,除了返回给用户之外,会复制一份在session中,在事务提交时,会用session中的备份和用户的数据进行比对,如果用户的数据状态改变, 则用户的数据即为:脏数 ...

  5. 【BZOJ 2154】Crash的数字表格

    制杖了,,,求前缀和的时候$i×i$是int,然后当$i=10^7$时就喜闻乐见地爆int了,,,对拍之后查了一个下午的错才发现这个问题,,,最后枚举用的变量全都强行加上long long才A掉 #i ...

  6. poj1966 求顶点连通度

    Cable TV Network Time Limit: 1000MS   Memory Limit: 30000K Total Submissions: 4563   Accepted: 2118 ...

  7. mnsday1t1

    贪心地选取两个后缀,然后往前补全,贪心地补全前k个不同的字符 我写了个沙茶dp,结果T掉了,明明都是n3的... #include<iostream> #include<stdio. ...

  8. 【Codeforces 723D】Lakes in Berland (dfs)

    海洋包围的小岛,岛内的有湖,'.'代表水,'*'代表陆地,给出的n*m的地图里至少有k个湖,求填掉面积尽量少的水,使得湖的数量正好为k. dfs找出所有水联通块,判断一下是否是湖(海水区非湖).将湖按 ...

  9. windows下为mysql添加日志

    mysql的配置文件 [mysqld] …… log-error="D:/phpStudy/log/mysql/mysql_log_err.txt" log="D:/ph ...

  10. Android复习资料

    转载:http://blog.csdn.net/huachao1001/article/details/53156582 在10月份开始就没有再参与校招了,面试过程真的很累,有时现场等面试一等就是几个 ...