- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我正在使用 Symfony acls,我注意到当第一次创建类 acl 时,还会使用 object_identifier = class 创建 acl_object_identities
但是如果你插入一个 ace 类,(acl_entries),object_identity_id 被设置为 NULL。我想知道为什么以前创建的 acl_object_identity 没有被使用?
表 acl_class :6 xxxxxxxx/我的类(class)
表 acl_object_identities63 NULL 6 类 1
表 acl_entries199 6 NULL 1 NULL 3 1073741823 1 所有 0 0
不应该是这个吗?199 6 63 1 NULL 3 1073741823 1 所有 0 0
我不明白为什么要创建一个标识对象类,但不与类条目一起使用。
这是我的代码,可能有问题:
//find or create acl
$classIdentity = new ObjectIdentity('class', ClassUtils::getRealClass($class));
$aclProvider = $this->getService('security.acl.provider');
try {
$acl = $aclProvider->findAcl($classIdentity);
} catch (AclNotFoundException $e) {
$acl = $aclProvider->createAcl($classIdentity);
}
//insert class aces
$maskBuilder = new MaskBuilder(128);
$securityId = new RoleSecurityIdentity('ROLE_ADMIN');
$acl->insertClassAce($securityId, $maskBuilder->get());
$aclProvider->updateAcl($acl);
谢谢
最佳答案
希望我已经正确阅读了您的问题。
acl_object_identities
表仅包含:对象标识。即使在创建基于类作用域的 ACE 时,您也必须提供有效的对象标识,并且通过使用名为 class
的“虚拟”标识符来实现。理论上,这可以是除 NULL
或空字符串之外的任何内容。在这些情况下,使用 class
是一种常见的约定。
请记住,ACL 理论上可以混合对象范围 ACE 和全局范围 ACE(即使有或没有字段)。如果 acl_object_identities
表中没有(虚拟)对象标识,您就不能直接使用 ACL,例如更新、删除。
您希望直接访问此类 ACL 的另一个原因是在不存在任何对象时检查权限:
$objectIdentity = new ObjectIdentity('class', 'The\Namespaced\Class');
if ($context->isGranted('CREATE', $objectIdentity)) {
... // seems you are allowed to create objects of this class
}
这会派上用场来检查类的“全局”CREATE
权限。
acl_entries
表包含所有 ACE,包括对象范围和类范围的 ACE。当 object_identity_id 设置为 NULL
时,条目是类范围的 ACE,否则它是对象范围的 ACE。类范围的 ACE 只需要知道使用了哪个类,并不真正关心对象标识,这就是该字段可以为空的原因。 class_id
字段在这些情况下用于确定类类型。
理论上,他们可以从 acl_entries
中删除 class_id
列,并始终使用 object_identity_id
代替,因为该表也有一个链接到 class_id
。但是,这将需要一个额外的连接,而且我们仍然需要在 ace_table
的某处添加条目是类范围 ACE 还是对象范围 ACE。
请记住,关于 ACL 的许多内容都是出于效率和速度原因而编写的,这有时会降低可读性。
关于php - Symfony 2 Acls insertClassAces,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26344016/
我开始从事一个用 Symfony 2.8 编写的大型项目。将整个项目升级到 SF 3 需要数百小时,现在还不可能。我想到了一个想法,将 symfony/symfony 包解压到它替换的单个包中(com
我在提交表单后使用 FOSUserEvents,但订阅者调用了两次。 这样我的验证码第一次有效第二次无效 这是我的代码 router = $router; $this->request
我有以下路线: blog_show: path: /test/123 defaults: { _controller: TotalcanBravofillBundle:Te
我是测试新手。我想测试我的功能。我已经成功安装了 phpUnit。我在互联网上查看了许多教程。但我无法获得有关测试的正确信息。这是我的功能代码: public function loginAction
我正在尝试重现 facebook batch requests 的行为在他们的图形 api 上运行。 所以我认为最简单的解决方案是在 Controller 上向我的应用程序发出几个请求,例如: pub
在 Symfony Progress Bar documentation有一个超酷酒吧的示例图像。不幸的是,看起来文档的其余部分没有解释如何获得这样的结果。 这是图片,以防您错过: 我怎么才能得到它?
我使用Finder发送假脱机电子邮件,但是自动名称生成器将点放在文件名中,有时它们出现在文件的开头。 查找程序似乎无法获取具有该名称的文件-那些文件被隐藏了……有人经历过这种行为吗?有什么建议如何使用
我正在尝试进行 LDAP 身份验证,我目前遇到此类错误: ServiceNotFoundException: The service "security.firewall.map.context.ma
有没有办法验证和检查集合数组是否为空。我已经尝试过: /** * @Assert\NotBlank() * @Assert\Length( min = 1) */ protected $work
使用Smyfony2和Doctrin2,可以使用以下示例创建数据固定装置:http://symfony.com/doc/current/bundles/DoctrineFixturesBundle/i
我看到在大多数Symfony 2示例中,例如,不存在记录时,Symfony 2会引发异常。我认为这种方法对最终用户不友好。为什么有人更喜欢引发异常而不在Flashbag上添加一些错误消息? 最佳答案
我对项目中的以下服务有疑问: app.security.guardAuthenticatorLoginPassword: class: AppBundle\Security\LoginPa
symfony缓存和登录Docker容器存在问题。 Web服务器从www-data用户和组执行,当我使用docker上安装的php从docker容器中清除symfony缓存时,它从root执行。 因此
我想了解 symfony 中的服务 我已阅读http://symfony.com/doc/2.3/book/service_container.html#creating-configuring-se
因为我对 Symfony 和 Doctrine 还很陌生,所以我有一个可能很愚蠢的问题;-) 有人可以用简单的词语向我解释集合(尤其是实体中的ArrayCollections)吗?它是什么以及何时以及
我收到了这个表格: {{ form_start(form) }} {{ form_end(form) }} 我想检查用户是否登录,我这样做了: {% if is_g
我的网站已准备好部署,我正在尝试将其设置为在线。 一些信息: 主持人是 OVH。 它不允许 SSH,我必须使用 FTP 发送文件。也没有命令行。 我现在希望能够在子目录中设置网站:/www/test(
过去几个月以来,我一直在尝试与symfony合作。昨晚我自动删除了不需要的存储库。之后,我无法使用symfony命令创建新的symfony项目。当我在终端中运行Symfony new Security
In the environnement variable, then in system variable, I edited the path and added在环境变量中,然后在系统变量
我们有一个 Symfony 1.4 应用程序,想升级到 Symfony 4。是否有可能或者我们必须重新编程该应用程序? 我们询问了我们附近的一家软件公司,他们告诉我们必须重新编写应用程序。 最佳答案
我是一名优秀的程序员,十分优秀!