gpt4 book ai didi

java - 使用带有 spring LDAP API 的 LDAP 进行身份验证,而不使用 spring security

转载 作者:行者123 更新时间:2023-12-01 09:20:42 25 4
gpt4 key购买 nike

我在我的 Sprint 启动应用程序中使用 spring-ldap-core 插件。基本上,LDAPTemplate - http://docs.spring.io/spring-ldap/docs/current/apidocs/org/springframework/ldap/core/LdapTemplate.html

我基本上想使用 Spring LDAP API 将下面的 xml 配置转换为 java,并希望避免使用 spring security。

我要转换的xml配置是 -

 <ldap-server id="ldapServer"
url="ldap://ad.company.com:389"
manager-dn="CN=serviceaccount,OU=Service Accounts,DC=ad,DC=company,DC=com"
manager-password="password"/>

<authentication-manager>
<ldap-authentication-provider
server-ref="ldapServer"
user-search-base="dc=ad,dc=company,dc=com"
user-search-filter="sAMAccountName={0}"
group-search-filter="member={0}"
group-search-base="ou=Groups,dc=ad,dc=company,dc=com"
group-role-attribute="cn"/>
</authentication-manager>

下面是我的java代码 -

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.ldap.core.LdapTemplate;
import org.springframework.ldap.core.support.LdapContextSource;
import org.springframework.ldap.authentication.DefaultValuesAuthenticationSourceDecorator;

@Configuration
public class LdapConfiguration {

@Bean
public LdapContextSource contextSource(){
LdapContextSource contextSource = new LdapContextSource();

contextSource.setUrl("ldap://ad.company.com:389");
contextSource.setBase("DC=ad,DC=company,DC=com");
contextSource.setUserDn("CN=serviceaccount,OU=Service Accounts,DC=ad,DC=company,DC=com");
contextSource.setPassword("password");
contextSource.afterPropertiesSet();
return contextSource;
}


@Bean
public LdapTemplate ldapTemplate(){

LdapTemplate template = new LdapTemplate(contextSource());
try {
template.afterPropertiesSet();
} catch (Exception e) {
e.printStackTrace();
}
return template;
}
}

这就是我尝试调用身份验证的方式 -如果发生身份验证,此代码片段所属的方法将返回一个 boolean 值

 AndFilter filter = new AndFilter();

filter.and(new EqualsFilter("sAMAccountName", userloginName));

return ldapTemplate.authenticate("OU=Service Accounts", filter.encode(), userPassword);

这不起作用,我得到的错误是:

No results found for search, base: 'OU=Service Accounts'; filter: '(sAMAccountName=usernameIinput)'.

我想知道如何使用 LDAP API 配置以下 xml 属性?

group-search-filter="member={0}"
group-search-base="ou=Groups,dc=ad,dc=company,dc=com"
group-role-attribute="cn"/>

此外,我还缺少什么?为什么这不起作用?任何帮助将不胜感激!

最佳答案

我能够弄清楚这一点。

//使用LDAPTemplate连接LDAP

@Configuration
public class LdapConfiguration {

@Bean
public LdapContextSource contextSource(){
LdapContextSource contextSource = new LdapContextSource();
contextSource.setUrl("ldap://companyurl.com:389");
contextSource.setUserDn("CN=serviceaccount,OU=Service Accounts,DC=ad,DC=company,DC=com");
contextSource.setPassword("secretpassword");
return contextSource;
}

@Bean
public LdapTemplate ldapTemplate(){
LdapTemplate template = new LdapTemplate(contextSource());
return template;
}
}

//认证部分

AndFilter filter = new AndFilter();
filter.and(new EqualsFilter("mailNickname", username));

Boolean authenticate = ldapTemplate.authenticate(base, filter.encode(), userpassword);

关于java - 使用带有 spring LDAP API 的 LDAP 进行身份验证,而不使用 spring security,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40180421/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com