Как перевести значения grails 2 в LDAP Active Directory для работы с Spring Boot - PullRequest
0 голосов
/ 03 июля 2018

У меня проблемы с подключением к Active Directory LDAP с использованием Spring Boot. Я использовал значения, найденные в нашем приложении Grails 2, но, должно быть, что-то упустил.

Grails 2 Пример значений

grails.plugin.springsecurity.ldap.authorities.retrieveDatabaseRoles = true
grails.plugin.springsecurity.ldap.context.managerDn = 'manager@domain.local'
grails.plugin.springsecurity.ldap.context.managerPassword = 'password'
grails.plugin.springsecurity.ldap.context.server = 'ldap://domain.local:389'
grails.plugin.springsecurity.ldap.authorities.ignorePartialResultException = true 
grails.plugin.springsecurity.ldap.search.base = 'ou=users,dc=domain,dc=local'
grails.plugin.springsecurity.ldap.search.filter = "sAMAccountName={0}"
grails.plugin.springsecurity.ldap.search.searchSubtree = true
grails.plugin.springsecurity.ldap.auth.hideUserNotFoundExceptions = false
grails.plugin.springsecurity.ldap.search.attributesToReturn = ['mail', 'displayName']
grails.plugin.springsecurity.providerNames = ['customAuthenticationProvider','ldapAuthProvider']

Вот один из многих вариантов, которые я пробовал в Spring Boot. Я уверен, что он не ищет менеджер / пароль правильно.

@Configuration
public class WebSecurityConfig extends WebSecurityConfigurerAdapter {

    @Override
    protected void configure(HttpSecurity http) throws Exception {
        http
            .authorizeRequests()
            .anyRequest().fullyAuthenticated()
            .and()
            .formLogin();
    }

    @Override
    public void configure(AuthenticationManagerBuilder auth) throws Exception {
        auth.ldapAuthentication()
            .contextSource().url("ldap://domain.local:389")
            .managerDn("uid=manager@domain.local,ou=users")
            .managerPassword("password")
            .and()
            .userSearchBase("ou=users,dc=domain,dc=local")
            .userDnPatterns("sAMAccountName={0}");

    }
}

зависимости build.gradle ldap

compile("org.springframework.ldap:spring-ldap-core")
compile("org.springframework.security:spring-security-ldap")
compile("com.unboundid:unboundid-ldapsdk")

1 Ответ

0 голосов
/ 03 июля 2018

Получилось, настроив так:

        auth.ldapAuthentication()
                .contextSource().url("ldap://domain.local:389/ou=users,dc=domain,dc=local")
                .managerDn("manager@domain.local").managerPassword("password")
                .and()
                .userSearchFilter("sAMAccountName={0}");
...