我正在尝试通过SSL连接查询LDAP。我收到了一份证书,然后运行:
keytool -import -trustcacerts -alias www.the-domain.com -file the-cert.der -keystore store.jks
然后,我将以下内容添加到Intellij的运行配置中,从而将我的Java程序指向证书:
-Djavax.net.ssl.trustStore=/path/to/store.jks
当我尝试连接时,我得到一个套接字关闭的异常。我是不是走错了一步?
以下是标准输出,稍作修改以删除IP信息:
javax.naming.ServiceUnavailableException: <ip:port>; socket closed
at com.sun.jndi.ldap.Connection.readReply(Connection.java:419)
at com.sun.jndi.ldap.LdapClient.ldapBind(LdapClient.java:340)
at com.sun.jndi.ldap.LdapClient.authenticate(LdapClient.java:192)
at com.sun.jndi.ldap.LdapCtx.connect(LdapCtx.java:2694)
at com.sun.jndi.ldap.LdapCtx.<init>(LdapCtx.java:293)
at com.sun.jndi.ldap.LdapCtxFactory.getUsingURL(LdapCtxFactory.java:175)
at com.sun.jndi.ldap.LdapCtxFactory.getUsingURLs(LdapCtxFactory.java:193)
at com.sun.jndi.ldap.LdapCtxFactory.getLdapCtxInstance(LdapCtxFactory.java:136)
at com.sun.jndi.ldap.LdapCtxFactory.getInitialContext(LdapCtxFactory.java:66)
at javax.naming.spi.NamingManager.getInitialContext(NamingManager.java:667)
at javax.naming.InitialContext.getDefaultInitCtx(InitialContext.java:288)
at javax.naming.InitialContext.init(InitialContext.java:223)
at javax.naming.InitialContext.<init>(InitialContext.java:197)
at javax.naming.directory.InitialDirContext.<init>(InitialDirContext.java:82)
at LDAPTool.main(LDAPTool.java:35)
发布于 2010-07-08 07:22:35
我发现了我的问题所在。我没有正确设置我的环境。
env.put(Context.SECURITY_PROTOCOL, "ssl");
显然,当使用ssl时,您需要指定安全协议,这是有意义的...
https://stackoverflow.com/questions/3159664
复制相似问题