dongzhong2674 2017-01-17 09:48
浏览 32
已采纳

Symfony Super Roles无法访问Base Roles

The Super Role has no access to the inherited Roles..??

This is how my role hierarchy looks like:

role_hierarchy:
    ROLE_ADMIN:           [ROLE_BACKEND_USER, ROLE_SALES]
    ROLE_SUPER_ADMIN:     ROLE_ADMIN
    ROLE_SALES:           ROLE_USER
    ROLE_BACKEND_USER:    ROLE_USER

When I log in as an ADMIN I can see that the I have inherited roles "ROLE_BACKEND_USER"; "ROLE_SALES" and "ROLE_USER".

However, I cannot access the ROLE_SALES though I have inherited the Role.

if(!$this->getUser()->hasRole('ROLE_SALES')) {

 throw new AccessDeniedException('Cannot loggin Need ROLE_SALES ');

}

Also $this->get('security.authorization_checker')->isGranted('ROLE_CARMANDO') does work..

P.S: Iam using FOS Bundle too.

  • 写回答

1条回答 默认 最新

  • dongyixun0634 2017-01-17 10:00
    关注

    This is because FOSUB hasRole method checks you explicitly have the role when isGranted checks the privileges.

    Currently, you have the privileges of the ROLE_SALES but not the ROLE_SALES itself. That's why isGranted works when hasRole does not

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 C++ yoloV5改写遇到的问题
  • ¥20 win11修改中文用户名路径
  • ¥15 win2012磁盘空间不足,c盘正常,d盘无法写入
  • ¥15 用土力学知识进行土坡稳定性分析与挡土墙设计
  • ¥70 PlayWright在Java上连接CDP关联本地Chrome启动失败,貌似是Windows端口转发问题
  • ¥15 帮我写一个c++工程
  • ¥30 Eclipse官网打不开,官网首页进不去,显示无法访问此页面,求解决方法
  • ¥15 关于smbclient 库的使用
  • ¥15 微信小程序协议怎么写
  • ¥15 c语言怎么用printf(“\b \b”)与getch()实现黑框里写入与删除?