Symfony2 cook book(http://symfony.com)から「データベース(エンティティプロバイダ)からセキュリティユーザを読み込む方法」に従ってきました。 /doc/current/cookbook/security/entity_provider.html)、私はカスタムエンティティプロバイダを使用していないことを除いて - つまり、私のUserクラスがロールに遅延ロードを使用していることを意味します。Symfony2のロール/グループ - is_grantedがユーザのロールを検出していない
セキュリティのファイアウォール/アクセス制御はすべて正常に機能します。 ROLE_ADMINユーザーだけがアクセスできるルートと、ROLE_USERユーザーがアクセスできるルートがあります。これらはうまくいきます。私のユーザーがデータベースにROLE_ADMINの役割を持っている(とそれに制限されたURLにアクセスできるにもかかわらず
<p>Logged in as: {{ app.user.username }} {% if is_granted('ROLE_ADMIN') %}| <a href="{{ path('bassettprovidentia_skeleton_admindashboard') }}">Admin area</a> {% endif %}| <a href="#">Settings</a> | <a href="{{ path('bassettprovidentia_skeleton_logout') }}">Log out</a></p>
:
問題は、私の基本テンプレートでは、私は次のように表示されるバーを持っているということですロール)、「Admin area」リンクは表示されません!
<p>Roles: {% for role in app.user.roles %}{{ role.name }} [{{ role.role }}]{% if not loop.last %}, {% endif %}{% endfor %}</p>
それは正常に動作します:同じ形式で
は、私は、これは持っています!ユーザーが持っているすべての役割が表示されます!私は間違っていますか?
遅延ロードは責任がありますか?
他にも問題はありません。
これで、ユーザープロバイダの役割を熱心に読み込むとどうなりますか? – Cerad