我尝试使用 silex 文档-Defining a custom Authentication Provider为 LDAP 身份验证编写自定义身份验证提供程序。
但是,如果我调查一下$app['security.authentication_providers']
,有两个提供者。我定义App\LdapAuthenticationProvider
的一个和一个 Symfony\Component\Security\Core\Authentication\Provider\DaoAuthenticationProvider
当我尝试授权用户时,我收到错误,因为有App\LdapUserProvider::loadUserByUsername()
来自类 DaoAuthenticationProvider 的调用。
如果我只有一个提供者,$app['security.authentication_providers']
我认为我不应该得到错误,因为我的 LDAP 提供者不调用 loadUserByUsername。
这是转储$app['security.authentication_providers']
array (size=2)
0 => object(App\LdapAuthenticationProvider)[194]
private 'userProvider' =>
object(App\LdapUserProvider)[176]
private 'ldap' => resource(57, ldap link)
private 'defaultRoles' =>
array (size=1)
...
private 'providerKey' => string 'default' (length=7)
1 => object(Symfony\Component\Security\Core\Authentication\Provider\DaoAuthenticationProvider)[195]
private 'encoderFactory' =>
object(Symfony\Component\Security\Core\Encoder\EncoderFactory)[197]
private 'encoders' =>
array (size=1)
...
private 'userProvider' =>
object(App\LdapUserProvider)[176]
private 'ldap' => resource(57, ldap link)
private 'defaultRoles' =>
array (size=1)
...
private 'hideUserNotFoundExceptions' (Symfony\Component\Security\Core\Authentication\Provider\UserAuthenticationProvider) => boolean true
private 'userChecker' (Symfony\Component\Security\Core\Authentication\Provider\UserAuthenticationProvider) => object(Symfony\Component\Security\Core\User\UserChecker)[196]
private 'providerKey' (Symfony\Component\Security\Core\Authentication\Provider\UserAuthenticationProvider) => string 'default' (length=7)
那么,有人知道为什么会有额外的提供者,我该如何摆脱它?
有用于引导应用程序、LdapAuthenticationListener和LdapAuthenticationProvider的代码。