3

在 Symfony 2(最新版本)下,我正在尝试更新我的实体:

php app/console doctrine:schema:upate --force

我在终端中收到此错误消息:

[Symfony\Component\Config\Definition\Exception\InvalidConfigurationException]
“security.firewalls.access_control”下无法识别的选项“0、1、2、3”

我是 Symfony 的新手,我不知道在哪里可以搜索来解决这个问题。

这是 security.yml 文件:

# To get started with security, check out the documentation:

http://symfony.com/doc/current/book/security.html

安全性:编码器: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:
    fos_userbundle:
        id: fos_user.user_provider.username

firewalls:
    # disables authentication for assets and the profiler, adapt it according to your needs
    main:
        pattern: ^/
        form_login:
            provider: fos_userbundle
            csrf_provider: security.csrf.token_manager # Use form.csrf_provider instead for Symfony <2.4

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

    #main:
        #anonymous: ~
        # 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

    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 }
4

3 回答 3

6
firewalls:
    main:
        pattern: ^/
        form_login:
            provider: fos_userbundle
            csrf_provider: security.csrf.token_manager # Use form.csrf_provider instead for Symfony <2.4

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


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 }
于 2015-08-16T09:02:41.533 回答
4

尝试缩进与防火墙相同级别的 access_control 部分

于 2015-08-15T20:11:02.733 回答
4

该错误与您尝试更新实体无关,而是指向security.yml配置文件的问题。在这种情况下,您的access_control部分的缩进不正确,应该与firewalls关键字处于相同的缩进级别。YAML 文件对缩进敏感,因此这应该对您的问题进行排序。

于 2015-08-15T19:28:31.667 回答