温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

创建一个简单的权限判断Access类

发布时间:2020-07-21 21:20:32 来源:网络 阅读:420 作者:phphan 栏目:开发技术

<?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>"; //要执行的操作   
}
?>

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI