在我的节点应用程序中,我有一个用例,我只需要对属于特定组的 LDAP 用户进行身份验证。如果用户不属于上述组,则身份验证应该失败。
我正在使用库ldapauth-fork进行 LDAP 身份验证。
我为过滤器尝试了各种方法,但它们都没有按预期工作。以下是我尝试过的尝试:
let ldapConnector = new LdapAuth (
{
url : config.ldap.url,
bindDN : config.ldap.bindDN,
adminPassword : config.ldap.adminPassword,
searchBase : config.ldap.searchBase,
searchFilter : "(&(sAMAccountName=testUser)(memberOf=testGroup))",
cache : true,
includeRaw : true,
log : logger
}
);
对于这种配置,no such user: "testuser"
即使用户是该testGroup
组的成员,我也总是会得到。
let ldapConnector = new LdapAuth (
{
url : config.ldap.url,
bindDN : config.ldap.bindDN,
adminPassword : config.ldap.adminPassword,
searchBase : config.ldap.searchBase,
searchFilter : "(sAMAccountName=testuser)",
groupSearchFilter : "(member=testGroup)"`
cache : true,
includeRaw : true,
log : logger
}
);
对于此配置,身份验证始终成功,即使组名是随机字符串。
那么,使身份验证工作的正确过滤字符串应该是什么?