首页 文章

Symfony FOSUserBundle无法登录

提问于
浏览
0

我正在使用带有FOSUserBundle的Symfony 3.1 .

我在Symfony中阅读了文档并集成了FOS,好了,注册似乎运行良好并且将数据保存到数据库中,但是,如果我尝试登录,我会再次作为匿名用户重定向到登录页面 .

我检查了Symfony Profiler,我可以看到,当它被称为路径/ login_check(在探查器中)时,用户结果被认证,但是在/ login_check阶段之后,当我被重定向时,用户是匿名的......

来自profiler的/ login_check:

适当的 Value

角色[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令牌)

(这是一个内联网,没有“主页”,当你打开要求登录的网站时)

为什么这个?

谢谢

2 回答

  • 0

    我不确定我理解你问的问题,但也许这就是你打开网站时被指示登录的原因?

    如果是这样,这就是原因:

    default_target_path: /redirLogIn
    

    将上面的内容更改为您需要的路径(路径) .

  • 0

    您需要改进文件中的缩进

    security:
        encoders:
            FOS\UserBundle\Model\UserInterface: bcrypt
    
        role_hierarchy:
            ROLE_ADMIN:       ROLE_USER
            ROLE_SUPER_ADMIN: ROLE_ADMIN
        # http://symfony.com/doc/current/book/security.html#where-do-users-come-from-user-providers
        providers:
            in_memory:
                memory: ~
            fos_userbundle:
                id: fos_user.user_provider.username_email
        firewalls:
            # disables authentication for assets and the profiler, adapt it according to your needs
            dev:
                pattern: ^/(_(profiler|wdt)|css|images|js)/
                security: false
    
            main:
                # activate different ways to authenticate
    
                # http_basic: ~
                # http://symfony.com/doc/current/book/security.html#a-configuring-how-your-users-will-authenticate
    
                # form_login: ~
                # http://symfony.com/doc/current/cookbook/security/form_login_setup.html
                pattern: ^/
                form_login:
                    provider: fos_userbundle
                    csrf_token_generator: security.csrf.token_manager
                    # if you are using Symfony < 2.8, use the following config instead:
                    # 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: ^/admin/, role: ROLE_ADMIN }
    

相关问题