<span style="background-color: rgb(247, 252, 255); font-family: Verdana, Arial, Helvetica, sans-serif; "></span><p><span style="font-family: Verdana, Arial, Helvetica,
sans-serif;

font-size: 14px;

background-color: rgb(247, 252, 255);

">CI 的钩子功能使得您能够在不改动系统核心文件的基础上来改变或添加系统的核心执行功能。</span></p><p><span style="font-family: Verdana, Arial, Helvetica, sans-serif;

font-size: 14px; background-color: rgb(247, 252, 255); ">

比如,您能够在控制器刚刚加载前或刚刚加载后来执行特定的脚本,或者在其它时刻来触发您的脚本。 

</span></p><p><span style="font-family: Verdana, Arial, Helvetica, sans-serif;

font-size: 14px;

background-color: rgb(247, 252, 255);

">看代码:</span></p><pre name="code" class="php"><span style="background-color: rgb(247, 252, 255); font-family: Verdana, Arial, Helvetica, sans-serif; "> 

</span> 

system/application/config/hooks.php中加入钩子声明:

[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'),//首页 www.2cto.com  

    '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 (emptyempty($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']); 

        } 

    } 

PHP之运用CI用钩子实现URL权限控制————————【Badboy】的更多相关文章

  1. 第十九章 动态URL权限控制——《跟我学Shiro》

    目录贴:跟我学Shiro目录贴 用过Spring Security的朋友应该比较熟悉对URL进行全局的权限控制,即访问URL时进行权限匹配:如果没有权限直接跳到相应的错误页面.Shiro也支持类似的机 ...

  2. Spring Security 动态url权限控制(三)

    一.前言 本篇文章将讲述Spring Security 动态分配url权限,未登录权限控制,登录过后根据登录用户角色授予访问url权限 基本环境 spring-boot 2.1.8 mybatis-p ...

  3. Shiro学习(19)动态URL权限限制

    用过spring Security的朋友应该比较熟悉对URL进行全局的权限控制,即访问URL时进行权限匹配:如果没有权限直接跳到相应的错误页面.Shiro也支持类似的机制,不过需要稍微改造下来满足实际 ...

  4. Spring Security-利用URL地址进行权限控制

    目的是:系统内存在很多不同的用户,每个用户具有不同的资源访问权限,具体表现就是某个用户对于某个URL是无权限访问的.需要Spring Security忙我们过滤. 参考:http://www.cnbl ...

  5. CI框架 .htaccess 隐藏url在index.php解决方案

    CodeIgniter(下面简称"CI")是一款国外优秀的PHP轻量级MVC框架,它支持PHP4和PHP5.是开发中小型可拓展性需求高的Web应用程序的利器.眼下你所见到的这个博客 ...

  6. 基于 URL 的权限控制

    先不用框架,自己实现一下 数据库 /* SQLyog v10.2 MySQL - 5.1.72-community : Database - shiro *********************** ...

  7. 在ASP.NET MVC中实现基于URL的权限控制

    本示例演示了在ASP.NET MVC中进行基于URL的权限控制,由于是基于URL进行控制的,所以只能精确到页.这种权限控制的优点是可以在已有的项目上改动极少的代码来增加权限控制功能,和项目本身的耦合度 ...

  8. springboot整合security实现基于url的权限控制

    权限控制基本上是任何一个web项目都要有的,为此spring为我们提供security模块来实现权限控制,网上找了很多资料,但是提供的demo代码都不能完全满足我的需求,因此自己整理了一版. 在上代码 ...

  9. 基于shiro+jwt的真正rest url权限管理,前后端分离

    代码地址如下:http://www.demodashi.com/demo/13277.html bootshiro & usthe bootshiro是基于springboot+shiro+j ...

随机推荐

  1. Wix打包系列(一)如何使用wix制作安装程序

    原文:Wix打包系列(一)如何使用wix制作安装程序 最近由于项目需要,需要给客户制作安装程序,一开始使用vs2005自带的打包工程来打包,但用了一段时间发现vs打包太死板,而且使用起来问题很多.收费 ...

  2. JDK源码分析—— ArrayBlockingQueue 和 LinkedBlockingQueue

    JDK源码分析—— ArrayBlockingQueue 和 LinkedBlockingQueue 目的:本文通过分析JDK源码来对比ArrayBlockingQueue 和LinkedBlocki ...

  3. poj3280(区间dp)

    题目连接:http://poj.org/problem?id=3280 题意:给定一个长度为m(m<=2000)的小写字母字符串,在给定组成该字符串的n(n<=26)个字符的添加和删除费用 ...

  4. C#的百度地图开发(三)依据坐标获取位置、商圈及周边信息

    原文:C#的百度地图开发(三)依据坐标获取位置.商圈及周边信息 我们得到了百度坐标,现在依据这一坐标来获取相应的信息.下面是相应的代码 public class BaiduMap { /// < ...

  5. Java 小样例:图书馆课程设计(Java 8 版)

    用 Java 模拟一个图书馆.包含创建图书.创建读者.借书.还书.列出全部图书.列出全部读者.列出已借出的图书.列出过期未还的图书等功能. 每一个读者最多仅仅能借 3 本书,每一个书最多仅仅能借 3 ...

  6. Android在如何建立一个WebServer

    今天老板交待任务最终完成了,感觉收获颇多,所以写一个关于它的记录,首先,看一下.老板的需求 需求: 希望移动端的用户标识(IMEI)和HTML页面的用户标识(Cookie)连接起来,当中HTML页面可 ...

  7. Java Executor 框架

    Java Executor 框架 Executor框架是指java5中引入的一系列并发库中与executor相关的功能类,包括Executor.Executors. ExecutorService.C ...

  8. 一个css和js结合的下拉菜单,支持主流浏览器

    首先声明: 本人尽管在web前端岗位干了好多年,但无奈岗位对技术要求不高.html,css用的比較多,JavaScript自己原创的非常少,基本都是copy改动,所以自己真正动手写时,发现基础非常不坚 ...

  9. oracle nologging用法(转)

    一.oracle日志模式分为(logging,force logging,nologging) 默认情况是logging,就是会记录到redo日志中,force logging是强制记录日志,nolo ...

  10. java获取指定地址图片高度宽度简单代码

    package com.test; import java.awt.image.BufferedImage; import java.io.IOException; import java.io.In ...