【问题标题】:FOSUserBundle - You must activate the logout in your security firewall configurationFOSUserBundle - 您必须在安全防火墙配置中激活注销
【发布时间】:2016-06-03 19:58:53
【问题描述】:

我正在使用带有 FOSUserBundle 的 Symfony 2.8.2。当我尝试注销时,出现以下错误:

您必须在安全防火墙配置中激活注销

这是我的 security.yml

security:
    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:
        main:
            pattern: ^/login
            form_login:
                provider: fos_userbundle
                csrf_token_generator: security.csrf.token_manager
            anonymous: true
            logout:
                path: /logout
                target: /login

    access_control:
        - { path: ^/logout$, role: IS_AUTHENTICATED_ANONYMOUSLY }
        - { 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 }

我也尝试设置 logout: true 但没有任何改变。

附:我没有使用 Sonata,只是 FOSUserBundle。

我收到此错误的原因是什么?

【问题讨论】:

标签: symfony security fosuserbundle firewall logout


【解决方案1】:

您必须添加您的 security.yml

firewalls:
       secured_area:   
              logout:
                  path:   /logout
                  target: /

在你的 routing.yml 中

logout:
    path: /logout

【讨论】:

    【解决方案2】:

    main 防火墙的模式似乎有误。

    设置pattern: ^/login 使此防火墙仅对匹配的 URL 有效,即只有 /login URL。

    此外,注销 URL 必须在防火墙的安全区域内。

    【讨论】:

      猜你喜欢
      • 2013-05-28
      • 2018-10-31
      • 1970-01-01
      • 2015-07-11
      • 1970-01-01
      • 2011-01-04
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多