如何使用语言环境保护 Action -在symfony1.4中,这非常容易。我现在使用symfony2.3:

我的security.yml:

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

    login:
        pattern:  frontend_account_login
        security: false


    secured_area:
        pattern:    ^/
        anonymous: ~
        http_basic:
            realm: "Secured Demo Area"
        form_login:
            check_path: frontend_account_security_check
            login_path: frontend_account_login
            use_referer:        true
            default_target_path: frontend_account_hello
        logout:
            path:   /logout
            target: frontend_account_login            #anonymous: ~
        #http_basic:
        #    realm: "Secured Demo Area"

access_control:
    #This works:
    - { path: ^/de/account/secured/, roles: ROLE_ADMIN }
    - { path: ^/en/account/secured/, roles: ROLE_ADMIN }
    #I want it kind of that way
    - { path: ^/{_locale}/account/secured/, roles: ROLE_ADMIN }

我读了一个带有正则表达式的帖子:^/[a-z] +/account/secured/。但这是行不通的。知道如何使用语言环境保护区域。我在这里找到了一些帖子,但它们都不起作用。

谢谢!!!

最佳答案

如果只有两个语言环境:

- { path: ^/(en|de)/account/secured/, roles: ROLE_ADMIN }

关于regex - 具有区域设置的安全区域,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/19513533/

10-10 22:55