我已经安装了FOSUserBundle
,我在我的项目中使用它。其登录页面重定向到未知路径/_wdt/50366043f414d
。我更改了default_target_path
文件中form_login
下的security.yml
,但没有生效。
如何在FOSUserBundle中更改登录页面的目标路径?
答案 0 :(得分:14)
我必须将always_use_default_target_path
设置为true
,如图所示
symfony documentation
#app/config/security.yml
firewalls:
main:
pattern: ^/
form_login:
login_path: /login
default_target_path: /my/desired/path
always_use_default_target_path: true
答案 1 :(得分:6)
我有同样的问题,我遇到这个问题的原因是因为Symfony试图加载Web调试工具栏(因此错误中的“_wdt”位),它有自己的路由,在页面加载结束。就我而言,我已经像我这样配置了security.yml:
security:
encoders:
FOS\UserBundle\Model\UserInterface: sha512
role_hierarchy:
ROLE_ADMIN: ROLE_USER
ROLE_SUPER_ADMIN: ROLE_ADMIN
providers:
fos_userbundle:
id: fos_user.user_provider.username
firewalls:
main:
pattern: ^/
form_login:
provider: fos_userbundle
csrf_provider: form.csrf_provider
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: ^/css, role: IS_AUTHENTICATED_ANONYMOUSLY }
- { path: ^/js, role: IS_AUTHENTICATED_ANONYMOUSLY }
- { path: ^/, role: ROLE_USER }
这意味着如果用户试图打开根“/”后面的任何内容的页面,则需要登录。
我解决问题的方法是添加“_wdt”部分并允许匿名用户:
access_control:
- { path: ^/login$, role: IS_AUTHENTICATED_ANONYMOUSLY }
- { path: ^/register, role: IS_AUTHENTICATED_ANONYMOUSLY }
- { path: ^/resetting, role: IS_AUTHENTICATED_ANONYMOUSLY }
- { path: ^/css, role: IS_AUTHENTICATED_ANONYMOUSLY }
- { path: ^/js, role: IS_AUTHENTICATED_ANONYMOUSLY }
- { path: ^/_wdt, role: IS_AUTHENTICATED_ANONYMOUSLY }
- { path: ^/, role: ROLE_USER }
答案 2 :(得分:1)
这可能是一个老问题,但是当前的Symfony2配置不是更改access_control,而是为调试工具栏提供额外的防火墙:
# Disabling the security for the web debug toolbar, the profiler and Assetic.
dev:
pattern: ^/(_(profiler|wdt)|css|images|js)/
security: false