首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >“csrf_token_generator”项下未识别的选项“security.firewalls.main.form_login”

“csrf_token_generator”项下未识别的选项“security.firewalls.main.form_login”
EN

Stack Overflow用户
提问于 2016-05-11 07:56:02
回答 1查看 2.5K关注 0票数 1

我正在尝试安装教程中的FOSUserBundle:https://symfony.com/doc/master/bundles/FOSUserBundle/index.html

但是出现了错误:

代码语言:javascript
复制
InvalidConfigurationException: Unrecognized options "csrf_token_generator" under "security.firewalls.main.form_login"

我的config.yml导入:-{资源: parameters.yml }-{ resource: security.yml }

代码语言:javascript
复制
framework:
    csrf_protection:
        enabled:  true
    #esi:             ~
    #translator:      { fallback: "%locale%" }
    secret:          "%secret%"
    router:
        resource: "%kernel.root_dir%/config/routing.yml"
        strict_requirements: ~
    form:            ~
    csrf_protection: ~
    validation:      { enable_annotations: true }
    templating:
        engines: ['twig']
        #assets_version: SomeVersionScheme
    default_locale:  "%locale%"
    trusted_hosts:   ~
    trusted_proxies: ~
    session:
        # handler_id set to null will use default session handler from php.ini
        handler_id:  ~
    fragments:       ~
    http_method_override: true

fos_user:
    db_driver: orm # other valid values are 'mongodb', 'couchdb' and 'propel'
    firewall_name: main
    user_class: Utilisateurs\UtilisateursBundle\Entity\Utilisateurs

# Twig Configuration
twig:
    debug:            "%kernel.debug%"
    strict_variables: "%kernel.debug%"

# Assetic Configuration
assetic:
    debug:          "%kernel.debug%"
    use_controller: false
    bundles:        [ ]
    #java: /usr/bin/java
    filters:
        cssrewrite: ~
        #closure:
        #    jar: "%kernel.root_dir%/Resources/java/compiler.jar"
        #yui_css:
        #    jar: "%kernel.root_dir%/Resources/java/yuicompressor-2.4.7.jar"

# Doctrine Configuration
doctrine:
    dbal:
        driver:   "%database_driver%"
        host:     "%database_host%"
        port:     "%database_port%"
        dbname:   "%database_name%"
        user:     "%database_user%"
        password: "%database_password%"
        charset:  UTF8
        # if using pdo_sqlite as your database driver:
        #   1. add the path in parameters.yml
        #     e.g. database_path: "%kernel.root_dir%/data/data.db3"
        #   2. Uncomment database_path in parameters.yml.dist
        #   3. Uncomment next line:
        #     path:     "%database_path%"

    orm:
        auto_generate_proxy_classes: "%kernel.debug%"
        auto_mapping: true

# Swiftmailer Configuration
swiftmailer:
    transport: "%mailer_transport%"
    host:      "%mailer_host%"
    username:  "%mailer_user%"
    password:  "%mailer_password%"
    spool:     { type: memory }

我的security.yml

代码语言:javascript
复制
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
            # if you are using Symfony < 2.8, use the following config instead:
            csrf_provider: form.csrf_provider

        logout:       true
        anonymous:    true
    dev:
        pattern:  ^/(_(profiler|wdt)|css|images|js)/
        security: false

    login:
        pattern:  ^/demo/secured/login$
        security: false

    secured_area:
        pattern:    ^/demo/secured/
        form_login:
            check_path: _security_check
            login_path: _demo_login
        logout:
            path:   _demo_logout
            target: _demo
        #anonymous: ~
        #http_basic:
        #    realm: "Secured Demo Area"

access_control:
    - { path: ^/login$, role: IS_AUTHENTICATED_ANONYMOUSLY }
    - { path: ^/register, role: IS_AUTHENTICATED_ANONYMOUSLY }
    - { path: ^/resetting, role: IS_AUTHENTICATED_ANONYMOUSLY }
    - { path: ^/, role: ROLE_ADMIN }

enter code here

有人能帮我吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-05-12 01:30:26

问题在您的security.yml文件中。您已经列出了两个CSRF令牌管理器。

代码语言:javascript
复制
firewalls:
    main:
        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

根据您正在使用的Symfony版本,如果您的Symfony版本小于2.8,则使用csrf_token_generatorcsrf_provider,而不是两者都使用。

您需要删除或注释其中的一行。

编辑这篇文章,因为我不能评论你的新帖子。

我的版本symfony是2.4:"symfony/symfony":“2.4.” 但我有个新错误: ServiceNotFoundException:您已经请求了一个不存在的服务"fos_user.doctrine_registry“。

这可能是因为您的Symfony版本是<2.6.*,并且与您正在使用的FOSUserBundle版本相冲突。

有关编辑config.yml的临时工作

代码语言:javascript
复制
services:
    fos_user.doctrine_registry:
        alias: doctrine
        # or use this, unsure on which one for your version of Symfony
        # alias: doctrine_mongodb

其他修复方法可能是在composer.json中使用特定的拉(不推荐旧版本)。这已经通过了Symfony 2.6.*的测试,并且绕过了您发布的同一个问题。

代码语言:javascript
复制
"friendsofsymfony/user-bundle": "dev-master##6ccff96434c0ac7fee077d1dce90966341dfd278"

您可以阅读有关这个特定问题的更多信息:https://github.com/FriendsOfSymfony/FOSUserBundle/issues/2048

一个Symfony分支也作为一个临时修复程序存在:https://github.com/symfony/symfony/pull/17554

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/37156379

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档