我正在使用带有 FOSUserBundle 的 Symfony 3.1。
我在 Symfony 中阅读了文档并集成了 FOS,好吧,注册似乎运行良好并将数据保存到数据库,但是,如果我尝试登录,我会再次以匿名用户身份重定向到登录页面。
我检查了 Symfony Profiler,我可以看到当它被称为路径 /login_check(在分析器中)时,用户结果是经过身份验证的,但是在 /login_check 阶段之后,当我被重定向时,用户是匿名的......
--
/login_check 来自探查器:
适当的价值
角色 [ROLE_USER]
继承的角色 无
令牌类 Symfony\Component\Security\Core\Authentication\Token\UsernamePasswordToken
--
会话似乎存在 (dump(app.session)) 不为空,但没有存储用户的数据。
那是我的security.yml:
安全:
encoders:
FOS\UserBundle\Model\UserInterface: bcrypt
role_hierarchy:
ROLE_ADMIN: ROLE_USER
ROLE_SUPER_ADMIN: ROLE_ADMIN
providers:
fos_userbundle:
id: fos_user.user_provider.username
firewalls:
# disables authentication for assets and the profiler, adapt it according to your needs
dev:
pattern: ^/(_(profiler|wdt)|css|images|js)/
security: false
main:
pattern: ^/
form_login:
provider: fos_userbundle
login_path: /login
check_path: /login_check
default_target_path: /redirLogIn
# csrf_token_generator: security.csrf.token_manager
logout: true
anonymous: true
access_control:
- { path: ^/login$, role: IS_AUTHENTICATED_ANONYMOUSLY }
- { path: ^/register, role: IS_AUTHENTICATED_ANONYMOUSLY }
- { path: ^/resetting, role: IS_AUTHENTICATED_ANONYMOUSLY }
# - { path: ^/admin.*, role: ROLE_ADMIN}
# - { path: ^/, role: ROLE_USER}
(由于注册问题,我禁用了 csrf 令牌)
(这是一个内网,没有“主页”,当您打开需要登录的站点时)
为什么这个?
谢谢