PHP之運用CI用鈎子實現URL權限控制


CI 的鈎子功能使得您可以在不修改系統核心文件的基礎上來改變或增加系統的核心運行功能。

例如,您可以在控制器剛剛載入前或剛剛載入后來運行特定的腳本,或者在其他時刻來觸發您的腳本。

看代碼:


system/application/config/hooks.php中添加鈎子聲明:


    
$hook['post_controller_constructor'] = array(
 'class' => 'Acl',
 'function' => 'filter',
 'filename' => 'acl.php',
 'filepath' => 'hooks',
);

system/application/config/config.php中讓鈎子系統生效
    
$config['enable_hooks'] = TRUE;

然后在中新建acl.php權限系統配置文件,當然你也可以放在數據庫中。

    
//游客權限映射
$config['acl']['visitor'] = array(
    '' => array('index'),//首頁
    'music' => array('index', 'list'),
    'user' => array('index', 'login', 'register')
);
//管理員
$config['acl']['admin'] = array(
 
);
 
//-------------配置權限不夠的提示信息及跳轉url------------------//
$config['acl_info']['visitor'] = array(
    'info' => '需要登錄以繼續',
    'return_url' => 'user/login'
);
 
$config['acl_info']['more_role'] = array(
    'info' => '需要更高權限以繼續',
    'return_url' => 'user/up'
);
 
/* End of file acl.php */
/* Location: ./application/config/acl.php */

system/application/hooks目錄下添加acl.php邏輯處理文件

    
class Acl
{
    private $url_model;//所訪問的模塊,如:music
    private $url_method;//所訪問的方法,如:create
    private $url_param;//url所帶參數 可能是 1 也可能是 id=1&name=test
    private $CI;
 
    function Acl()
    {
        $this->CI = & get_instance();
        $this->CI->load->library('session');
 
        $url = $_SERVER['PHP_SELF'];
        $arr = explode('/', $url);
        $arr = array_slice($arr, array_search('index.php', $arr) + 1, count($arr));
        $this->url_model = isset($arr[0]) ? $arr[0] : '';
        $this->url_method = isset($arr[1]) ? $arr[1] : 'index';
        $this->url_param = isset($arr[2]) ? $arr[2] : '';
    }
 
    function filter()
    {
        $user = $this->CI->session->userdata('user');
        if (empty($user)) {//游客visitor
            $role_name = 'visitor';
        } else {
            $role_name = $user->role;
        }
 
        $this->CI->load->config('acl');
        $acl = $this->CI->config->item('acl');
        $role = $acl[$role_name];
        $acl_info = $this->CI->config->item('acl_info');
 
        if (array_key_exists($this->url_model, $role) && in_array($this->url_method, $role[$this->url_model])) {
            ;
        } else {//無權限,給出提示,跳轉url
            $this->CI->session->set_flashdata('info', $acl_info[$role_name]['info']);
            redirect($acl_info[$role_name]['return_url']);
        }
    }
}




免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM