how to accept self-signed certificates for JNDI/LDAP connections?

前端 未结 6 1600
死守一世寂寞
死守一世寂寞 2020-12-13 15:33

I need to connect to an LDAP directory over SSL.

In non-production environments, we use self-signed certificates which, of course, fails to validate with:

         


        
6条回答
  •  难免孤独
    2020-12-13 16:21

    According to the JNDI documentation it seems possible to set a custom SSLSocketFactory

    http://download.oracle.com/javase/1.5.0/docs/guide/jndi/jndi-ldap-gl.html#socket

    public class MySSLSocketFactory extends SocketFactory {
        private static final AtomicReference defaultFactory = new AtomicReference<>();
    
        private SSLSocketFactory sf;
    
        public MySSLSocketFactory() {
            KeyStore keyStore = ... /* Get a keystore containing the self-signed certificate) */
            TrustManagerFactory tmf = TrustManagerFactory.getInstance();
            tmf.init(keyStore);
            SSLContext ctx = SSLContext.getInstance("TLS");
            ctx.init(null, tmf.getTrustManagers(), null);
            sf = ctx.getSocketFactory();
        }
    
        public static SocketFactory getDefault() {
            final MySSLSocketFactory value = defaultFactory.get();
            if (value == null) {
                defaultFactory.compareAndSet(null, new MySSLSocketFactory());
                return defaultFactory.get();
            }
            return value;
        }
    
        @Override
        public Socket createSocket(final String s, final int i) throws IOException {
            return sf.createSocket(s, i);
        }
    
        @Override
        public Socket createSocket(final String s, final int i, final InetAddress inetAddress, final int i1) throws IOException {
            return sf.createSocket(s, i, inetAddress, i1);
        }
    
        @Override
        public Socket createSocket(final InetAddress inetAddress, final int i) throws IOException {
            return sf.createSocket(inetAddress, i);
        }
    
        @Override
        public Socket createSocket(final InetAddress inetAddress, final int i, final InetAddress inetAddress1, final int i1) throws IOException {
            return sf.createSocket(inetAddress, i, inetAddress1, i1);
        }
    }
    

    Configure the environment to use this socket factory

    env.put("java.naming.ldap.factory.socket", "com.example.MySSLSocketFactory");
    

提交回复
热议问题