実現したい事は題名の通りです。
クライアントサーバーからjavaを通してOpenLDAPのLDAPサーバーにSSL接続し、特定のユーザー情報を取り出すプログラムを作りたいのです。
LDAPサーバーには自己証明書が配置されているのでのSSL認証の検証も回避したいです。
検証用にテストユーザーを取得するコードを、下記サイトを参考に書きました。
LDAPクライアントプログラミングは怖くない(Java編)
Java
1 2import java.util.Hashtable; 3 4import javax.naming.Context; 5import javax.naming.NamingEnumeration; 6import javax.naming.NamingException; 7import javax.naming.directory.Attribute; 8import javax.naming.directory.DirContext; 9import javax.naming.directory.InitialDirContext; 10import javax.naming.directory.SearchControls; 11import javax.naming.directory.SearchResult; 12 13public class LDAPClientTest { 14 15 public static void main(String[] args) throws NamingException { 16 17 Hashtable<String, String> env = new Hashtable<String, String>(); 18 env.put(Context.INITIAL_CONTEXT_FACTORY, "com.sun.jndi.ldap.LdapCtxFactory"); 19 env.put(Context.PROVIDER_URL, "LDAPのドメイン"); 20 env.put(Context.SECURITY_AUTHENTICATION, "simple"); 21 env.put(Context.SECURITY_PRINCIPAL, "バインド対象"); 22 env.put(Context.SECURITY_CREDENTIALS, "パスワード"); 23 DirContext dirContext = new InitialDirContext(env); 24 25 SearchControls searchControls = new SearchControls(); 26 searchControls.setSearchScope(SearchControls.SUBTREE_SCOPE); 27 searchControls.setReturningAttributes(new String[]{"uid", "cn", "sn"}); 28 NamingEnumeration<SearchResult> result = 29 dirContext.search("ベースのdc", "(テストユーザ)", searchControls); 30 System.out.println("----- Search Result -----"); 31 while (result.hasMore()) { 32 SearchResult searchResult = result.next(); 33 NamingEnumeration<? extends Attribute> attrEnum = searchResult.getAttributes().getAll(); 34 while (attrEnum.hasMore()) { 35 Attribute attribute = attrEnum.next(); 36 NamingEnumeration<?> valueEnum = attribute.getAll(); 37 while (valueEnum.hasMore()) { 38 System.out.println(attribute.getID() + ": " + valueEnum.next()); 39 } 40 } 41 42 } 43 44 } 45} 46
ただ、こちらを実行するとException in thread "main" javax.naming.CommunicationException: simple bind failed: LDAPサーバー [Root exception is java.net.SocketException: Connection or outbound has closed]
というエラーが出てしまいました。
おそらく、証明書をクライアント側のサーバーにインポートしていない事が原因だというところまでは推測できたのですが、実装に手間取っています。
SSLのベリファイアをドスルーする
こういったコードも調べたのですが、どの文書もhttps接続に関することが多く、どうやって実装していいのかもわかりません。
証明書の検証を無視する、という方向で解決方法を教えて頂きたいです。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2021/06/09 02:48