11

FOSUserBundleをインストールした後、user / userpassでログインしようとしていますが、「Badcredentials」メッセージが表示されます。これは私のsecurity.ymlです:

security:
    encoders:
        Symfony\Component\Security\Core\User\User: plaintext

    role_hierarchy:
        ROLE_ADMIN:       ROLE_USER
        ROLE_SUPER_ADMIN: [ROLE_USER, ROLE_ADMIN, ROLE_ALLOWED_TO_SWITCH]

    providers:
        in_memory:
            users:
                user:  { password: userpass, roles: [ 'ROLE_USER' ] }
                admin: { password: adminpass, roles: [ 'ROLE_ADMIN' ] }
        fos_userbundle:
            id: fos_user.user_manager

    firewalls:
        main:
            pattern: ^/
            form_login:
                provider: fos_userbundle
            logout:       true
            anonymous:    true
            #anonymous: ~
            #http_basic:
            #    realm: "Secured Demo Area"

何か案が?

symfony 2.0.4

4

4 に答える 4

22

次のようにプロバイダーをチェーンします。

providers:
    chain_provider:
        providers: [in_memory, fos_userbundle]
    in_memory:
        users:
            user:  { password: userpass, roles: [ 'ROLE_USER' ] }
            admin: { password: adminpass, roles: [ 'ROLE_ADMIN' ] }

    fos_userbundle:
        id: fos_user.user_manager

    firewalls:
        main:
            pattern: ^/
            form_login:
                provider: chain_provider
            logout:       true
            anonymous:    true
            switch_user:  true
        dev:
            pattern:  ^/(_(profiler|wdt)|css|images|js)/
            security: false
于 2011-10-30T01:53:44.220 に答える
5

ファイアウォール セクションで、間違ったプロバイダーを使用しています: in_memory ではなく fos_userbundle です。必要に応じて、それらを連鎖させることができます。

于 2011-10-27T14:48:37.367 に答える
2

ユーザー プロバイダーのチェーンに加えて、Web アプリケーションでパスワードをエンコードすることをお勧めします

encoders:
    "Symfony\Component\Security\Core\User\User":
        algorithm:   sha1
        iterations: 1
        encode_as_base64: false
    "FOS\UserBundle\Model\UserInterface": sha512

providers:
chain_provider:
    providers: [in_memory, fos_userbundle]
in_memory:
    users:
        user:  { password: 45f106ef4d5161e7aa38cf6c666607f25748b6ca, roles: [ 'ROLE_USER' ] } # userpass as password
        admin: { password: 74913f5cd5f61ec0bcfdb775414c2fb3d161b620, roles: [ 'ROLE_ADMIN' ] } # adminpass as password

fos_userbundle:
    id: fos_user.user_manager

firewalls:
    main:
        pattern: ^/
        form_login:
            provider: chain_provider
        logout:       true
        anonymous:    true
        switch_user:  true
    dev:
        pattern:  ^/(_(profiler|wdt)|css|images|js)/
        security: false
于 2012-02-04T15:38:15.767 に答える
0

次のように、symfony 2.3 のプロバイダーをチェーンします。

providers:

    in_memory:
        users:
            user:  { password: userpass, roles: [ 'ROLE_USER' ] }
            admin: { password: adminpass, roles: [ 'ROLE_ADMIN' ] }

    fos_userbundle:
        id: fos_user.user_manager

    chain_provider:
        chain:
            providers: [in_memory, fos_userbundle]

    firewalls:
        main:
            pattern: ^/
            form_login:
                provider: chain_provider
            logout:       true
            anonymous:    true
            switch_user:  true
        dev:
            pattern:  ^/(_(profiler|wdt)|css|images|js)/
            security: false
于 2013-10-23T19:20:43.513 に答える