Php 无法识别的选项“;csrf令牌发生器&x201D;在“;security.firewalls.main.form#u login”;

Php 无法识别的选项“;csrf令牌发生器&x201D;在“;security.firewalls.main.form#u login”;,php,symfony,csrf,fosuserbundle,Php,Symfony,Csrf,Fosuserbundle,我正在按照教程安装FOSUserBundle: 但是出现了错误: InvalidConfigurationException: Unrecognized options "csrf_token_generator" under "security.firewalls.main.form_login" My config.yml 进口: -{resource:parameters.yml} -{资源:security.yml} framework: csrf_protection:

我正在按照教程安装FOSUserBundle:

但是出现了错误:

InvalidConfigurationException: Unrecognized options "csrf_token_generator" under "security.firewalls.main.form_login"
My config.yml 进口: -{resource:parameters.yml} -{资源:security.yml}

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:
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
安全性:
编码器:
FOS\UserBundle\Model\UserInterface:bcrypt
角色层次结构:
角色\管理员:角色\用户
角色超级管理员:角色管理员
供应商:
fos_用户包:
id:fos\u user.user\u provider.username
防火墙:
主要内容:
模式:^/
表格(u)登入:
提供商:fos_用户包
csrf_令牌_生成器:security.csrf.token_管理器
#如果您使用的是Symfony<2.8,请改用以下配置:
csrf\u提供程序:form.csrf\u提供程序
注销:正确
匿名:是的
开发人员:
模式:^/((探查器wdt)| css |图像| js)/
安全性:错误
登录:
模式:^/demo/secured/login$
安全性:错误
安全区:
模式:^/演示/安全/
表格(u)登入:
检查路径:\u安全性\u检查
登录路径:\演示\登录
注销:
路径:\演示\注销
目标:演示
#匿名:~
#http_basic:
#领域:“安全演示区”
访问控制:
-{path:^/login$,角色:已通过身份验证\u匿名}
-{path:^/register,role:IS_AUTHENTICATED_ANONYMOUSLY}
-{路径:^/正在重置,角色:是否以匿名方式进行身份验证}
-{路径:^/,角色:角色\管理员}
在这里输入代码

有人能帮我吗?

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

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
其他修复可能在composer.json中使用特定的pull(旧版本-不推荐)。这已经针对Symfony 2.6.*进行了测试,并且绕过了您发布的同一问题

"friendsofsymfony/user-bundle": "dev-master##6ccff96434c0ac7fee077d1dce90966341dfd278"
您可以阅读有关此特定问题的更多信息:

Symfony分支也作为临时修复程序存在:

"friendsofsymfony/user-bundle": "dev-master##6ccff96434c0ac7fee077d1dce90966341dfd278"