技术文档:AclManagerBundle 安装与使用指南
2024-12-25 09:51:59作者:邵娇湘
1. 安装指南
1.1. 添加依赖
首先,需要在你的 composer.json
文件中添加以下依赖:
{
"require": {
"problematic/acl-manager-bundle": "dev-master"
}
}
然后,执行 composer install
或者 composer update
来安装这个包。
1.2. 注册Bundle
接着,在 app/AppKernel.php
文件中注册这个Bundle:
<?php
// app/AppKernel.php
public function registerBundles()
{
return array(
// ...
new Problematic\AclManagerBundle\ProblematicAclManagerBundle(),
);
}
1.3. 配置ACL
如果没有配置ACL,需要在 app/config/security.yml
文件中启用它:
# app/config/security.yml
security:
acl:
connection: default
最后,运行ACL初始化命令:
php app/console init:acl
2. 项目使用说明
AclManagerBundle 提供了一个 AclManager
类,用于管理实体的访问控制列表(ACL)。以下是如何使用这个类的基本示例:
<?php
$comment = new Comment(); // 创建一个实体
// ... 对实体进行操作
$em->persist($comment);
$em->flush(); // 实体必须被持久化和刷新后,AclManager 才能作用于它(需要标识符)
$aclManager = $this->get('problematic.acl_manager');
// 添加一个权限,不考虑之前存在的其他权限
$aclManager->addObjectPermission($comment, MaskBuilder::MASK_OWNER, $userEntity);
// 或者:
$aclManager->addObjectPermission($comment, MaskBuilder::MASK_OWNER);
// 替换所有当前权限为新的权限
$aclManager->setObjectPermission($comment, MaskBuilder::MASK_OWNER, $userEntity);
// 撤销特定权限
$aclManager->revokePermission($comment, MaskBuilder::MASK_DELETE, $userEntity);
// 撤销所有权限
$aclManager->revokeAllObjectPermissions($comment, $userEntity);
// 类似地,也可以使用类权限:
$aclManager->addClassPermission($comment, MaskBuilder::MASK_OWNER, $userEntity);
$aclManager->setClassPermission($comment, MaskBuilder::MASK_OWNER, $userEntity);
$aclManager->revokePermission($comment, MaskBuilder::MASK_DELETE, $userEntity, 'class');
$aclManager->revokeAllClassPermissions($comment, $userEntity);
// 你也可以使用对象字段权限...
$aclManager->addObjectFieldPermission($comment, 'title', MaskBuilder::MASK_EDIT, $userEntity);
$aclManager->setObjectFieldPermission($comment, 'title', MaskBuilder::MASK_EDIT, $userEntity);
$aclManager->revokeFieldPermission($comment, 'title', MaskBuilder::MASK_DELETE, $userEntity);
$aclManager->revokeAllObjectFieldPermissions($comment, 'title', $userEntity);
// ...以及类字段范围权限:
$aclManager->addClassFieldPermission($comment, 'title', MaskBuilder::MASK_EDIT, $userEntity);
$aclManager->setClassFieldPermission($comment, 'title', MaskBuilder::MASK_EDIT, $userEntity);
$aclManager->revokeFieldPermission($comment, 'title', MaskBuilder::MASK_DELETE, $userEntity, 'class');
$aclManager->revokeAllClassFieldPermissions($comment, 'title', $userEntity);
// 删除ACL
$aclManager->deleteAclFor($comment);
$em->remove($comment);
$em->flush();
如果没有提供 $userEntity
,则默认使用当前会话用户。
如果你将处理大量实体,可以使用 AclManager#preloadAcls()
方法:
<?php
$products = $repo->findAll();
$aclManager = $this->get('problematic.acl_manager');
$aclManager->preloadAcls($products);
// ...继续操作
3. 项目API使用文档
AclManagerBundle 的API主要是通过 AclManager
类来提供的。以下是一些常用的API方法:
addObjectPermission($object, $mask, $userEntity = null)
setObjectPermission($object, $mask, $userEntity = null)
revokePermission($object, $mask, $userEntity = null)
revokeAllObjectPermissions($object, $userEntity = null)
addClassPermission($object, $mask, $userEntity = null)
setClassPermission($object, $mask, $userEntity = null)
revokeAllClassPermissions($object, $userEntity = null)
addObjectFieldPermission($object, $field, $mask, $userEntity = null)
setObjectFieldPermission($object, $field, $mask, $userEntity = null)
revokeFieldPermission($object, $field, $mask, $userEntity = null, $class = false)
revokeAllObjectFieldPermissions($object, $field, $userEntity = null)
deleteAclFor($object)
preloadAcls($objects)
这些方法提供了对实体和类级别的访问控制权限的添加、设置、撤销和预加载功能。
4. 项目安装方式
项目的安装方式已在上述“安装指南”部分详细描述。总结如下:
- 在
composer.json
中添加依赖。 - 使用
composer install
或composer update
安装依赖。 - 在
AppKernel.php
中注册Bundle。 - 配置
security.yml
文件中的ACL。 - 运行
init:acl
命令初始化ACL。
以上就是AclManagerBundle的安装与使用指南。希望本文档能够帮助您更好地理解和应用这个Bundle。
热门项目推荐
相关项目推荐
- 鸿蒙开发工具大赶集本仓将收集和展示鸿蒙开发工具,欢迎大家踊跃投稿。通过pr附上您的工具介绍和使用指南,并加上工具对应的链接,通过的工具将会成功上架到我们社区。07
- LangChatLangChat: Java LLMs/AI Project, Supports Multi AI Providers( Gitee AI/ 智谱清言 / 阿里通义 / 百度千帆 / DeepSeek / 抖音豆包 / 零一万物 / 讯飞星火 / OpenAI / Gemini / Ollama / Azure / Claude 等大模型), Java生态下AI大模型产品解决方案,快速构建企业级AI知识库、AI机器人应用Java03
- 每日精选项目🔥🔥 01.24日推荐项目:微软21节课程,入门生成式AI🔥🔥 每日推荐行业内最新、增长最快的项目,快速了解行业最新热门项目动态~~027
- source-vue🔥 一直想做一款追求极致用户体验的快速开发平台,看了很多优秀的开源项目但是发现没有合适的。于是利用空闲休息时间对若依框架进行扩展写了一套快速开发系统。如此有了开源字节快速开发平台。该平台基于 Spring Boot + MyBatis + Vue & Element ,包含微信小程序 & Uniapp, Web 报表、可视化大屏、三方登录、支付、短信、邮件、OSS...Java02
- Cangjie-Examples本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。Cangjie047
- 毕方Talon工具本工具是一个端到端的工具,用于项目的生成IR并自动进行缺陷检测。Python039
- PDFMathTranslatePDF scientific paper translation with preserved formats - 基于 AI 完整保留排版的 PDF 文档全文双语翻译,支持 Google/DeepL/Ollama/OpenAI 等服务,提供 CLI/GUI/DockerPython06
- mybatis-plusmybatis 增强工具包,简化 CRUD 操作。 文档 http://baomidou.com 低代码组件库 http://aizuda.comJava03
- 国产编程语言蓝皮书《国产编程语言蓝皮书》-编委会工作区018
- advanced-javaAdvanced-Java是一个Java进阶教程,适合用于学习Java高级特性和编程技巧。特点:内容深入、实例丰富、适合进阶学习。JavaScript0109
热门内容推荐
最新内容推荐
项目优选
收起
Python-100-Days
Python - 100天从新手到大师
Python
373
72
HarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
276
72
Cangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
200
47
xzs-mysql
学之思开源考试系统是一款 java + vue 的前后端分离的考试系统。主要优点是开发、部署简单快捷、界面设计友好、代码结构清晰。支持web端和微信小程序,能覆盖到pc机和手机等设备。 支持多种部署方式:集成部署、前后端分离部署、docker部署
HTML
5
1
LangChat
LangChat: Java LLMs/AI Project, Supports Multi AI Providers( Gitee AI/ 智谱清言 / 阿里通义 / 百度千帆 / DeepSeek / 抖音豆包 / 零一万物 / 讯飞星火 / OpenAI / Gemini / Ollama / Azure / Claude 等大模型), Java生态下AI大模型产品解决方案,快速构建企业级AI知识库、AI机器人应用
Java
10
3
gin-vue-admin
🚀Vite+Vue3+Gin的开发基础平台,支持TS和JS混用。它集成了JWT鉴权、权限管理、动态路由、显隐可控组件、分页封装、多点登录拦截、资源权限、上传下载、代码生成器【可AI辅助】、表单生成器和可配置的导入导出等开发必备功能。
Go
16
3
source-vue
🔥 一直想做一款追求极致用户体验的快速开发平台,看了很多优秀的开源项目但是发现没有合适的。于是利用空闲休息时间对若依框架进行扩展写了一套快速开发系统。如此有了开源字节快速开发平台。该平台基于 Spring Boot + MyBatis + Vue & Element ,包含微信小程序 & Uniapp, Web 报表、可视化大屏、三方登录、支付、短信、邮件、OSS...
Java
24
2
CangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
898
0
madong
基于Webman的权限管理系统
PHP
4
0
cool-admin-java
🔥 cool-admin(java版)一个很酷的后台权限管理框架,Ai编码、流程编排、模块化、插件化、CRUD极速开发,永久开源免费,基于springboot3、typescript、vue3、vite、element-ui等构建
Java
18
2