Symfony 4 Fos用户在不同路径上重定向
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Symfony 4 Fos用户在不同路径上重定向相关的知识,希望对你有一定的参考价值。
我已经设置了一个角色:{ path: ^/, role: ROLE_USER }
,如果没有通过/login
验证,它会重定向。如何更改此重定向网址?
在我的security.yaml下面:
security:
encoders:
FOSUserBundleModelUserInterface: sha512
role_hierarchy:
ROLE_ADMIN: ROLE_USER
ROLE_SUPER_ADMIN: [ROLE_USER, ROLE_ADMIN, ROLE_ALLOWED_TO_SWITCH]
# https://symfony.com/doc/current/security.html#where-do-users-come-from-user-providers
providers:
fos_userbundle:
id: fos_user.user_provider.username
firewalls:
dev:
pattern: ^/(_(profiler|wdt)|css|images|js)/
security: false
main_login:
pattern: ^/(fr|en|zh)/login$
anonymous: true
main:
pattern: ^/
form_login:
provider: fos_userbundle
csrf_token_generator: security.csrf.token_manager
check_path: fos_user_security_check
default_target_path: iot6_HomeBundle
logout:
path: fos_user_security_logout
target: fos_user_security_login
anonymous: true
# Easy way to control access for large sections of your site
# Note: Only the *first* access control that matches will be used
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 }
#- { path: ^/login, roles: IS_AUTHENTICATED_ANONYMOUSLY, requires_channel: https }
答案
如果我正确理解您的问题,您需要覆盖FOSUserBundle的路线。像那样:
#config/routes/fos_user.yaml
fos_user:
resource: "@FOSUserBundle/Resources/config/routing/all.xml"
# ...
fos_user_security_login:
path: /yourRoute/login
defaults: { _controller: FOSUserBundle:Security:login, _method: POST }
以上是关于Symfony 4 Fos用户在不同路径上重定向的主要内容,如果未能解决你的问题,请参考以下文章
无法解析 symfony 4.3 中覆盖 FOS 控制器的参数 $token
Symfony 4/JMS/FOSUser:无法从 FOS\UserBundle 序列化数据
Symfony 4.4 FOS user-bundle api/auth/login 在 null 上调用成员函数 findOneBy()