php - symfony - IS_AUTHENTICATED_ANONYMOUSLY 不工作

标签 php symfony fosuserbundle

我从 Symfony 的旅程开始。
在这一点上,我试图保护我的身份验证路由(我正在使用 FOSUserBundle),所以我这样做:

access_control:
    - { path: ^/logowanie$, role: IS_AUTHENTICATED_ANONYMOUSLY }
    - { path: ^/rejestracja, role: IS_AUTHENTICATED_ANONYMOUSLY }
    - { path: ^/resetowanie-hasla, role: IS_AUTHENTICATED_ANONYMOUSLY }
    - { path: ^/backstage/, role: ROLE_ADMIN }
    - { path: ^/profile/, role: ROLE_USER }

但是,无论是否登录,我都可以访问这些路线。
我的坏在哪里?
# To get started with security, check out the documentation:
# https://symfony.com/doc/current/security.html
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: ^/
            form_login:
                provider: fos_userbundle
                csrf_token_generator: security.csrf.token_manager
                check_path: fos_user_security_check
                login_path: fos_user_security_login
            logout:
                path: fos_user_security_logout
                target: website.home
            logout:       true
            anonymous:    true

    access_control:
        - { path: ^/logowanie$, role: IS_AUTHENTICATED_ANONYMOUSLY }
        - { path: ^/rejestracja, role: IS_AUTHENTICATED_ANONYMOUSLY }
        - { path: ^/resetowanie-hasla, role: IS_AUTHENTICATED_ANONYMOUSLY }
        - { path: ^/backstage/, role: ROLE_ADMIN }
        - { path: ^/profile/, role: ROLE_USER }

最佳答案

您应该限制已登录用户的访问权限,现在如果用户已登录,还具有角色 IS_AUTHENTICATED_ANONYMOUSLY ,这是角色层次结构。

- { path: ^/logowanie$, role: IS_AUTHENTICATED_ANONYMOUSLY && !IS_AUTHENTICATED_FULLY }                

关于php - symfony - IS_AUTHENTICATED_ANONYMOUSLY 不工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45267611/

相关文章:

php - Symfony - 教义2中的子查询

php - 如何将 Symfony 形式的 MoneyType 输入覆盖为 ="number"类型?

forms - Symfony2 - 一个 Action 中的多种形式

php - 如何在 Symfony4 结构的参数文件中检索我的环境变量?

javascript - FOSUserBundle AJAX 使用 Symfony2 登录(路由)

symfony - FOSUserBundle登录时的区域设置切换

symfony - 用 fosuser 覆盖注册 Controller 无法 Autowiring 服务 "App\Controller\RegistrationController"

php - Magento 在哪里设置报价项目的价格?

php - 我将如何确定电子邮件地址实际存在与否?

php - 如何在同一个 Doctrine2 对象上正确插入或更新