防火墙配置如下:
firewalls:
login_firewall:
pattern: ^/login$
anonymous: ~
secured_area:
pattern: ^/
login_form: ~
登录后,除了 /login 页面,其他页面都可以通过 $this->getUser()
获得当前用户信息,
请问,在 /login 页面如何获取当前用户信息?
根据回答我解决了问题,下面是我的 security.yml 内容:
security:
role_hierarchy:
ROLE_ADMIN: ROLE_USER
firewalls:
# login_firewall:
# pattern: ^/login$
# anonymous: ~
secured_area:
pattern: ^/
anonymous: ~
form_login:
login_path: login
check_path: login_check
logout:
path: /logout
target: /
access_control:
- { path: ^/login$, roles: IS_AUTHENTICATED_ANONYMOUSLY }
- { path: ^/, roles: ROLE_USER }
providers:
in_memory:
memory:
users:
kevin: { password: kevinpass, roles: 'ROLE_USER' }
admin: { password: adminpass, roles: 'ROLE_ADMIN' }
encoders:
Symfony\Component\Security\Core\User\User: plaintext
同时我在SO上也找到了一个与之类似的提问 - 链接
感谢回答的朋友!
你可以删掉login那个firewall,在acl里配置: