更新我从来不知道为什么下面的security.yml文件不工作,但我确实学到了一些东西,可能会帮助某人在未来。我不知道这是否100 %准确,但似乎login_path和check_path密钥不适用于路由名称,您需要使用实际的路径(例如/login)。而且,在yaml模式和匿名模式中,提供者密钥应该处于相同的级别,而不是在ldapsecure下,如下所示。
当我试图使用Symfony 2.6配置自定义身份验证提供程序时,会出现此错误。
Unrecognized options "check_path, login_path, provider" under "security.firewalls.secured_area.ldapsecure"这是我的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:
ldap_provider:
id: ldap.security.user.provider
firewalls:
login_firewall:
pattern: ^/app/login$
anonymous: ~
secured_area:
pattern: ^/
ldapsecure:
check_path: app_security_login_check
login_path: app_security_login_path
provider: ldap_provider
dev:
pattern: ^/(_(profiler|wdt)|css|images|js)/
security: false
access_control:
- { path: ^/app/login, roles: IS_AUTHENTICATED_ANONYMOUSLY }
- { path: ^/, roles: ROLE_USER }ldapsecure“工厂”类是存在的,如果我将getKey()方法更改为返回其他人,它会以不同的方式中断,因此将识别ldapsecure。但我不明白它为什么不接受check_path、login_path或提供者。如果我将ldapsecure更改为form_login,我就不会得到错误,它只是没有使用我的身份验证提供程序。
所以我觉得我错过了什么,但不知道该从哪里看。
发布于 2016-03-29 21:29:29
在ldapsecure工厂中,将addConfiguration方法的主体更改为:
public function addConfiguration(NodeDefinition $node)
{
$node
->children()
->scalarNode('check_path')
->isRequired()
->end()
->scalarNode('login_path')
->isRequired()
->end()
->scalarNode('provider')
->isRequired()
->end()
->end();
}这应该能让它发挥作用。
https://stackoverflow.com/questions/30125083
复制相似问题