phalcon: 目录分组后的acl权限控制

楼主在做acl权限的时候,发现官方的acl只能针对未分组的目录,如下:

app/
___|./controller
___|./logic
___|./plugins
___|./models
..............

  

但是对分组不支持,后来想想,是支持的.分组的目录如下

app/
___|./admin/
__________|./controllers
__________|./logic
__________|./views
__________|./module.php
___|./home/
__________|./controllers
__________|./logic
__________|./views
__________|./module.php
.........................................

  

那么可以将,如下代码,直接加入到,分组目录下的 module.php代码中

$di['aclResource']=function(){
return include_once '../app/configs/frontAcl.php';
};
$di['dispatcher'] = function(){
$eventManager = new \Phalcon\Events\Manager();
$securyDeep = new \SecurityDeep();
$eventManager->attach("dispatch", $securyDeep);
$dispatch = new \Phalcon\Mvc\Dispatcher();
$dispatch->setEventsManager($eventManager);
return $dispatch;
};

  

全代码:

use Phalcon\Loader,
Phalcon\Mvc\Url,
Phalcon\Mvc\Dispatcher,
Phalcon\DiInterface,
Phalcon\Mvc\ModuleDefinitionInterface,
Phalcon\DI\Injectable,
Phalcon\Mvc\Router; class Module extends Injectable implements ModuleDefinitionInterface
{ /**
* Registers the module auto-loader
*/
public function registerAutoloaders(DiInterface $dependencyInjector = null)
{
$loader = new Loader();
$loader->registerNamespaces(array(
'App\Home\Controllers' => __DIR__ .'/controllers/'
))->register();
$loader->registerDirs(
array(
'modelsDir' => '../app/models/',
'pluginsDir' => '../app/plugins/',
)
)->register(); } /**
* Registers the module-only services
*
* @param DiInterface $di
*/
public function registerServices(DiInterface $di)
{ $di['aclResource']=function(){
return include_once '../app/configs/frontAcl.php';
};
$di['dispatcher'] = function(){
$eventManager = new \Phalcon\Events\Manager();
$securyDeep = new \SecurityHome();
$eventManager->attach("dispatch", $securyDeep);
$dispatch = new \Phalcon\Mvc\Dispatcher();
$dispatch->setEventsManager($eventManager);
return $dispatch;
}; /**
* @return mixed
*/
$di['baseUrl'] = function () {
$url = new Url();
$url->setBaseUri('/');
return $url;
}; /**
* 设置view
*/
$di->set('view', function () use($di) {
$view = new \Phalcon\Mvc\View();
//var_dump($di['modules']['home']['viewsDir']);exit;
$view->setViewsDir(BASE_PATH . $di['modules']['home']['viewsDir']);
$view->registerEngines(array(
'.phtml' => 'Phalcon\Mvc\View\Engine\Php'
));
return $view; }); } }

  

acl文件:

return new \Phalcon\Config(array(
'Manager'=>array(
'rote'=> new \Phalcon\Acl\Role("Manager"),
'resource'=>array(
//登录
'Index'=> array("index", 'error'),
//用户中心
'User'=> array("center", 'password','editcenter','editpwd','login','loginout'),
//verzhun登录
'Veryzhun'=>array('login','logining'), //默认所有权限
'Capacity'=>array('index','airline','route'),
'Clearance'=>array('airport','route'),
'Operate'=>array('factor','compare'),
'Traffic'=>array('index','history','monitor'),
'Utilization'=>array('moment','night'), )
),
'Operator'=>array(
'rote'=> new \Phalcon\Acl\Role("Operator"),
'resource'=>array(
'Index'=> array("index", 'error'),
'User'=> array("center", 'password','editcenter','editpwd','login','loginout'),
'Veryzhun'=>array('login','logining'),
'Traffic'=>array('index','history','monitor'), //默认所有权限
//'Capacity'=>array('index','airline','route'),
'Clearance'=>array('airport','route'),
'Operate'=>array('factor','compare'),
'Traffic'=>array('index','history','monitor'),
'Utilization'=>array('moment','night'),
)
)
));

  

权限验证:

/**
* 权限控制
*/
use \Phalcon\Mvc\User\Plugin,
\Phalcon\Events\Event,
\Phalcon\Mvc\Dispatcher;
class SecurityHome extends Plugin{ public function __construct() { } public function _getAcl()
{
$acl = new \Phalcon\Acl\Adapter\Memory(); //默认权限禁止
$acl->setDefaultAction(\Phalcon\Acl::DENY);
//读取所有权限
$aclResource = $this->_callAcl(); if(!empty($aclResource))
{
foreach ($aclResource as $key=>$value)
{ //创建角色到acl
$acl->addRole($value['rote']);
//所有的操作
foreach ((array)$value['resource'] as $k=>$v)
{
//echo $k.'<br>';
foreach((array)$v as $ky=>$vy)
{
//添加资源
$acl->addResource(new \Phalcon\Acl\Resource(strtolower($k)), $vy);
//添加访问权限
$acl->allow($key, strtolower($k), $vy);
//echo '|--'.$k.':'.$vy.'<br>';
}
}
}
} return $acl; } public function _callAcl()
{
if($this->persistent->acl == null || $this->persistent->acl['Operator']['rote'] == null)
{
$this->persistent->acl = $this->aclResource;
}
return $this->persistent->acl;
} /**
* 事件触发
* @param Event $event
* @param Dispatcher $dispatcher
*/
public function beforeExecuteRoute(Event $event, Dispatcher $dispatcher)
{ $controller = $dispatcher->getControllerName();
$action = $dispatcher->getActionName(); //权限
$role = 'Operator';
$acl = $this->_getAcl();
$isAllowed = $acl->isAllowed($role, strtolower($controller), strtolower($action)); if(!$isAllowed)
{ $dispatcher->forward(array(
'controller'=>'index',
'action'=>'error',
'params'=>array('msg'=>'no access')
));
//echo "no access";
//exit;
}
} }

  

接收获取到的数据:

/**
* 提示页面
*/
public function errorAction()
{
//获取传过来的参数
$param = $this->dispatcher->getParams();
$msg = isset($param['msg']) ? $param['msg'] : '' ; $this->view->web_title = '错误';
$this->view->pick('index/error');
}

  

phalcon: 目录分组后的acl权限控制的更多相关文章

  1. Linux系统——ACL权限控制及特殊权限

    ACL权限控制 ACL(access control list),可以提供除属主.属组.其他人的rwx权限之外的细节权限设定 ACL的权限控制 (1)User 使用者 (2)Group 群组 (3)M ...

  2. zookeeper的ACL权限控制

    ACL:Access Control List  访问控制列表 1.  简介 0.概述 ACL 权限控制,使用:scheme:id:perm 来标识,主要涵盖 3 个方面: 权限模式(Scheme): ...

  3. 1.ZooKeeper ACL权限控制

    参考:https://blog.csdn.net/liuxiao723846/article/details/79391650 ZK 类似文件系统,Client 可以在上面创建节点.更新节点.删除节点 ...

  4. <实训|第十三天>linux中ACL权限控制以及磁盘配额,附编译属于自己的linux内核

    [root@localhost~]#序言 首先讲讲昨天关于缩容失败,开不机的解决方法:ACL权限也算是一个很重要的知识点,不难,但是很实用:磁盘配额一般不需要自己弄,但是要懂得原理.剩下的就是编译属于 ...

  5. ACL权限控制列表

    1.查看文件系统是否支持ACL (xfs文件系统强制开启ACL,如果该分区已格式化为xfs,在使用dumpe2fs会看不到superblocks信息)zheng@ubuntu16:~$ sudo du ...

  6. ZooKeeper学习之路(五)—— ACL权限控制

    一.前言 为了避免存储在Zookeeper上的数据被其他程序或者人为误修改,Zookeeper提供了ACL(Access Control Lists)进行权限控制.只有拥有对应权限的用户才可以对节点进 ...

  7. ZooKeeper系列(五)—— ACL 权限控制

    一.前言 为了避免存储在 Zookeeper 上的数据被其他程序或者人为误修改,Zookeeper 提供了 ACL(Access Control Lists) 进行权限控制.只有拥有对应权限的用户才可 ...

  8. Linux下ACL权限控制以及用sudo设置用户对命令的执行权限

    ACL权限分配 1.setfacl命令设置文件权限 setfacl -m u:user1:rw root.txt setfacl -m u:user2:rwx root.txt 2.getfacl命令 ...

  9. LInux ACL权限控制

    1.ACL简介 ACL是一种可以实现灵活的权限管理(文件的额外赋权机制)除了文件所有者,所属组和其他人,可以对更多的用户设置权限,这就是访问控制列表(Access Control List) 2.AC ...

随机推荐

  1. git零散知识

    集中式与分布式的差别: 集中式的服务器挂了所有人都挂了,因为完整仓库只存在服务器上,分布式如果github挂了你可以重新建一个服务器,然后把任何一个人的仓库clone过去 一句话总结:分布式版本控制的 ...

  2. Centos Docker1.12 远程Rest api访问的配置方法

    Docker默认是没有开启HTTP远程访问的,默认只支持通过unix socket通信操作docker daemon,需要使用HTTP restful接口需要修改配置. 1.修改配置文件,文件位置/l ...

  3. CXF框架介绍及Spring集成

    1.CXF框架概念介绍 Apache CXF 是一个开源的 WebService 框架,CXF可以用来构建和开发 WebService,这些服务可以支持多种协议,比如:SOAP.POST/HTTP.H ...

  4. [转]Algolia的分布式搜索网络架构

    转自:http://www.csdn.net/article/2015-03-11/2824176-the-architecture-of-algolias-distributed-search-ne ...

  5. sgu 101 Domino 解题报告及测试数据

    101. Domino time limit per test: 0.25 sec. memory limit per test: 4096 KB 题解: 求多米诺骨牌按照一定方式放置能否使相邻的位置 ...

  6. 优化netbeans启动速度

    NetBeans优化的目的是提高NetBeans的启动速度和运行速度.下面介绍的NetBeans优化技巧是在版本6.0beta2上的优化.经过实验,大大提高了NetBeans的启动速度. 1,修改英文 ...

  7. [转]HTML标签元素的分类

      在讲解CSS布局之前,我们需要提前知道一些知识,在CSS中,html中的标签元素大体被分为三种不同的类型:块状元素.内联元素和内联块状元素. 常用的块状元素有: <div>.<p ...

  8. IDEA 安装插件报错 Plugin Lombok Plugin was not installed: Cannot download

    报错 解决 成功下载插件 3

  9. Cisco 路由交换 常用查询语句

    基本信息查询语句 #查看全配置信息 #show running-configure #查看vlan信息 #show vlan brief #查看物理直连信息 #show cdp neighbors d ...

  10. 20145301Java课程总结

    20145301 Java课程总结 每周读书笔记链接汇总 第一周读书笔记: http://www.cnblogs.com/5301z/p/5248888.html 第二周读书笔记: http://ww ...