您好,登錄后才能下訂單哦!
<?php
class Access{
/**
* 類的唯一實例
*/
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 Access();
}
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;
}
}
@session_start();
$_SESSION['role'] = 'user';
$pruview=Access::getInstance();
//獲取權限類的實例
$pruview->usertype=$_SESSION['role'];
//設置角色
$pruview->usertype = $_SESSION['role'];
//獲取該角色擁有的權限
$arr = $pruview->getpur();
echo '該用戶的權限有:' . join(',', $arr) . "\n";
//判斷執行的操作是否有權限
if (true === $pruview->check(Access::CREATE))
{
create(); //要執行的操作
}
else
{
exit("<br><span style='color:red;'>您沒有權限!</span>");
}
//去掉用戶的添加權限
$pruview->delPur(Access::CREATE);
$arr = $pruview->getpur();
echo '<br>該用戶的權限有:' . join(',', $arr) . "\n";
//執行添加操作
if (true === $pruview->check(Access::CREATE))
{
create(); //要執行的操作
}
else
{
echo "<br><span style='color:red'>您沒有權限!</span><br>" . "\n";
}
//加上用戶的添加權限
$pruview->addPur(Access::EDIT);
$arr = $pruview->getpur();
echo '<br>該用戶的權限有:' . join(',', $arr) . "\n";
//執行添加操作
if (true === $pruview->check(Access::EDIT))
{
edit(); //要執行的操作
}
else
{
echo "<br><span style='color:red'>您沒有權限!</span>" . "\n";
}
//創建的方法
function create(){
echo "<br><span style='color:green;'>執行創建操作</span><br>"; //要執行的操作
}
//編輯的方法
function edit(){
echo "<br><span style='color:green;'>執行編輯操作</span><br>"; //要執行的操作
}
?>
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。