我目前正在尝试使用Spring Boot 1.4.2.RELEASE构建一个小型的and应用程序,为此,我还使用了Spring Boot LDAP,其中嵌入了LDAP和ldif。如果我开始这样做,它总是告诉我没有设置DN,如下所示。
所以如果我遗漏了什么,有人可以告诉我如何让它运行。我已经尝试了一些教程中的示例ldif文件,但总是得到相同的结果。
以下是我的配置的一些部分:- Java 8- Spring Boot 1.4.2版本- Spring Annotation而不是xml - Gradle
build.gradle:
... springBootVersion = '1.4.2.RELEASE'
compile ('org.springframework.boot:spring-boot-starter-web') {
exclude module: 'org.springframework.boot:spring-boot-starter-tomcat'
}
compile 'org.springframework.boot:spring-boot-starter-jetty',
'org.springframework.boot:spring-boot-starter-data-jpa',
'org.springframework.boot:spring-boot-starter-data-rest',
'org.springframework.boot:spring-boot-starter-freemarker',
'org.springframework.boot:spring-boot-starter-security',
'org.springframework.boot:spring-boot-actuator',
'org.springframework.boot:spring-boot-devtools',
'org.springframework.security:spring-security-ldap',
'org.springframework:spring-tx',
'com.h2database:h2',
'org.apache.directory.server:apacheds-server-jndi:1.5.5'
testCompile 'org.springframework.boot:spring-boot-starter-test',
'org.springframework.security:spring-security-test'
...配置:
@Configuration
@EnableWebSecurity
public class SecurityConfiguration extends WebSecurityConfigurerAdapter {
@Override
protected void configure(HttpSecurity httpSecurity) throws Exception {
httpSecurity
.authorizeRequests()
.anyRequest().fullyAuthenticated()
.and()
.formLogin();
}
@Autowired
public void configureGlobal(AuthenticationManagerBuilder auth) throws Exception {
auth
.ldapAuthentication()
.userSearchFilter("uid={0}")
.userSearchBase("ou=users")
.groupSearchBase("ou=groups")
.groupSearchFilter("(uniqueMember={0}")
.groupRoleAttribute("cn")
.rolePrefix("ROLE")
.contextSource().ldif("classpath:test.ldif")
.root("o=mojo");
}……
test.ldif:
version: 1
dn: o=mojo
objectClass: organization
objectClass: extensibleObject
objectClass: top
o: mojo
dn: ou=users,o=mojo
objectClass: extensibleObject
objectClass: organizationalUnit
objectClass: top
ou: users
dn: ou=groups,o=mojo
objectClass: extensibleObject
objectClass: organizationalUnit
objectClass: top
ou: groups
dn: cn=User,ou=groups,o=mojo
objectClass: groupOfUniqueNames
objectClass: top
cn: User
uniqueMember: cn=John Milton,ou=users,o=mojo
uniqueMember: cn=Robert Browning,ou=users,o=mojo
uniqueMember: cn=Hugo Williams,ou=users,o=mojo
uniqueMember: cn=John Keats,ou=users,o=mojo
dn: cn=Admin,ou=groups,o=mojo
objectClass: groupOfUniqueNames
objectClass: top
cn: Admin
uniqueMember: cn=Hugo Williams,ou=users,o=mojo
uniqueMember: cn=John Keats,ou=users,o=mojo
dn: cn=Robert Browning,ou=users,o=mojo
objectClass: organizationalPerson
objectClass: person
objectClass: inetOrgPerson
objectClass: top
cn: Robert Browning
sn: Browning
uid: rbrowning
userPassword:: cGFzcw==
...错误消息:
2016-11-25 22:45:58.383 INFO 15028 --- [ restartedMain] o.s.s.ldap.server.ApacheDSContainer : Loading LDIF file: C:\SourceCode\Zeiterfassung\src\main\resources\test.ldif
2016-11-25 22:45:58.391 WARN 15028 --- [ restartedMain] o.a.d.shared.ldap.ldif.LdifReader : No version information : assuming version: 1
2016-11-25 22:45:58.391 ERROR 15028 --- [ restartedMain] o.a.d.shared.ldap.ldif.LdifReader : A ldif entry must start with a DN
2016-11-25 22:45:58.392 ERROR 15028 --- [ restartedMain] o.a.d.s.p.shared.store.LdifFileLoader : Failed to import LDIF into backing store.
javax.naming.NamingException: No DN for entry
at org.apache.directory.shared.ldap.ldif.LdifReader.parseDn(LdifReader.java:562) ~[shared-ldap-0.9.15.jar:na]
at org.apache.directory.shared.ldap.ldif.LdifReader.parseEntry(LdifReader.java:1234) ~[shared-ldap-0.9.15.jar:na]
at org.apache.directory.shared.ldap.ldif.LdifReader.init(LdifReader.java:282) ~[shared-ldap-0.9.15.jar:na]
at org.apache.directory.shared.ldap.ldif.LdifReader.<init>(LdifReader.java:329) ~[shared-ldap-0.9.15.jar:na]
at org.apache.directory.server.protocol.shared.store.LdifFileLoader.execute(LdifFileLoader.java:181) ~[apacheds-protocol-shared-1.5.5.jar:na]
at org.springframework.security.ldap.server.ApacheDSContainer.importLdifs(ApacheDSContainer.java:280) [spring-security-ldap-4.1.3.RELEASE.jar:4.1.3.RELEASE]
at org.springframework.security.ldap.server.ApacheDSContainer.start(ApacheDSContainer.java:216) [spring-security-ldap-4.1.3.RELEASE.jar:4.1.3.RELEASE]
at org.springframework.security.ldap.server.ApacheDSContainer.afterPropertiesSet(ApacheDSContainer.java:134) [spring-security-ldap-4.1.3.RELEASE.jar:4.1.3.RELEASE]
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.invokeInitMethods(AbstractAutowireCapableBeanFactory.java:1642) [spring-beans-4.3.4.RELEASE.jar:4.3.4.RELEASE]非常感谢你的帮助
AirBounce
发布于 2019-04-09 22:59:35
我通过删除application.yml中的验证属性为自己修复了这个问题
在此之前:
spring:
ldap:
embedded:
base-dn: dc=example,dc=com
ldif: classpath:test-server.ldif
port: 12745
validation:
enabled: true现在是:
spring:
ldap:
embedded:
base-dn: dc=example,dc=com
ldif: classpath:test-server.ldif
port: 12745如果有任何来自嵌入式ldap服务器的日志记录,那么查找此类问题将更加容易。
发布于 2017-02-10 18:47:28
通过查看您提供的日志,可以看出您的ldif文件(version: 1)的第一行没有考虑在内:
15028 -11-25 22:45:58.391 WARN 2016- restartedMain o.a.d.shared.ldap.ldif.LdifReader :无版本信息:假设版本为1
顺便说一下,你提供的版本看起来是默认的,所以你可以删除它。
然后,我想它会起作用的。
问候
发布于 2017-06-21 19:48:55
我的问题是在我的ldif文件中有一个字节顺序标记。如果删除BOM,则Apache DS能够处理该文件。
https://stackoverflow.com/questions/40813006
复制相似问题