php – Symfony2 – 访问被拒绝

发布时间:2022-04-30 发布网站:脚本宝典
脚本宝典收集整理的这篇文章主要介绍了php – Symfony2 – 访问被拒绝脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在为我的项目使用Symfony2,我创建了两个页面.一个登录页面一个索引页面.我已成功登录管理员帐户(使用ROLE_ADMIN).
但是我收到了403 Forbidden页面,其中包含以下错误

这是我在security.yML中的配置:

access_control: 
   - { path: ^/vs/login,roles: IS_AUTHENTICATED_ANONYMOUSLY }
   - { path: ^/vs/index,roles: ROLE_ADMIN }

当我var_dump用户.我看到角色是空的:

PRivate 'roles' => 
    object(Doctrine\ORM\PErsistentCollection)[293]
      private 'snapshot' => 
        array (size=0)
          empty

这是我的User.PHP的角色:

/**
 * @ORM\ManyToMany(targetEntITy="Role",inversedBy="users")
 * @ORM\JoinTable(name="user_role",* joinColumns={@ORM\JoinColumn(name="user_id",referencedColumnName="id")},* inverseJoinColumns={@ORM\JoinColumn(name="role_id",referencedColumnName="id")}
 * )
 */
private $roles;

这是我使用$user-> getRoles()时得到的:

array (size=1)
  0 => 
    object(...\Entity\Role)[397]
      private 'id' => int 1
      private 'name' => string 'admin' (length=5)
      private 'role' => string 'ROLE_ADMIN' (length=10)
      private 'users' => 
        object(Doctrine\ORM\PersistentCollection)[398]
          private 'snapshot' => 
            array (size=0)

我做错了什么?

解决方法

学说关系注释是错误的:

/** 
 * @ORM\ManyToMany(targetEntity="Role",inversedBy="users") 
 */ 
private $roles; 

/**
 * @ORM\ManyToMany(targetEntity="User",mappedBy="roles") 
 */ 
private $users;

脚本宝典总结

以上是脚本宝典为你收集整理的php – Symfony2 – 访问被拒绝全部内容,希望文章能够帮你解决php – Symfony2 – 访问被拒绝所遇到的问题。

如果觉得脚本宝典网站内容还不错,欢迎将脚本宝典推荐好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。