Solved

Getting "unable to find valid certification path to requested target" when using ldaps.

Posted on 2008-10-13
6
12,778 Views
Last Modified: 2013-11-24
Hi All,

We are having an application that connects to the LDAP through JNDI ssl/non-ssl. When it tries to connect through SSL it throws the following exception in Windows (uses sun JRE)

Root exception is javax.net.ssl.SSLHandshakeException: sun.security.validator.ValidatorException: PKIX path building failed: sun.security.provider.certpath.SunCertPathBuilderException: unable to find valid certification path to requested target.

For this exception, I have tried quite a bit of things from internet. Most of them say that I have to install the rootCA certificate. Nothing helped.

The value of the trust store is assigned at the run-time (in the JNDI code) using the api
System.setProperty("javax.net.ssl.trustStore", c:\\certificates\\mystore);

In AIX (using IBM JRE), the same code throws the following exception.

Root exception is javax.net.ssl.SSLHandshakeException: com.ibm.jsse2.util.h: PKIX path building failed: java.security.cert.CertPathBuilderException: PKIXCertPathBuilderImpl could not build a valid CertPath.; internal cause is:java.security.cert.CertPathValidatorException: The certificate issued by <DN of the CA> is not trusted; internal cause is: java.security.cert.CertPathValidatorException: Certificate chaining error

Our application has a application server, webserver and a database. To isolate the problem, I wrote a standalone JNDI program. It connects to the same LDAP with same set of certs from the same machine (both Windows and AIX) through SSL.

Finally I found out 2 ways to make the application work.

1. When I import the certificates in to jssecacerts iniside the jre\lib\security I am able to connect through SSL. The trust store path is not necessary here.
2. When I give the path of the trust store along with the Java VM options in my appserver configuration file and reboot, it works. I think it is similar to giving the keystore path in the command line, i.e.,

c:\> java -Djavax.net.ssl.trustStore=c:\\certificates\\mystore

From this I would say the certificates are not the problem. My app is not able to get the trust store path when I set the path at runtime or the value of the path gets overwritten at some point.

Unfortunately I can resort to any of the above 2 solutions. Have anyone come across these kind of problems? Any help would be appreciated.

0
Comment
Question by:ppjoe
  • 2
  • 2
6 Comments
 
LVL 5

Expert Comment

by:muktajindal
ID: 22708367
0
 

Author Comment

by:ppjoe
ID: 22708607
Thanks Muktajindal.
The link you have given has instructions and example to write a standalone JNDI code. I have done it and it works for me. I have already mentioned this. The problem I am facing is the same snippet of working code in standalone does not work with my app. From the various test case I have almost concluded that the trust store path is not picked up by the JNDI. So, my problem is very specific to the truststore path. This is an example (which works as standalone) I am trying that fails to connect inside my app.

Hashtable envProps = new Hashtable();

envProps.put(Context.SECURITY_AUTHENTICATION, "simple");

envProps.put(Context.SECURITY_PRINCIPAL, "cn=xyz");

envProps.put(Context.SECURITY_CREDENTIALS, "xyz");

envProps.put(Context.INITIAL_CONTEXT_FACTORY, "com.sun.jndi.ldap.LdapCtxFactory");

envProps.put(Context.SECURITY_PROTOCOL, "ssl");

    

System.setProperty("javax.net.ssl.trustStore", "c:\\certificates\\cert");

//I dont write in to the trust store. So the trust store password is not needed.

   

envProps.put(Context.PROVIDER_URL, "ldap://mycomputer.ldap.com:636");

InitialLdapContext context = null;

try

{

context = new InitialLdapContext(envProps, null);

}

catch (Exception e)

{}	

Open in new window

0
 
LVL 5

Accepted Solution

by:
muktajindal earned 500 total points
ID: 22708796
Make sure that the truststore path is correct w.r.t. the server/machine where this piece of code is running.
0
 

Author Comment

by:ppjoe
ID: 22719861
I found out the property that is set using
System.setProperty("javax.net.ssl.trustStore", "c:\\certificates\\cert");
is not picked up by the JVM. The value is set but my app is not picking it.
0

Featured Post

Is Your Active Directory as Secure as You Think?

More than 75% of all records are compromised because of the loss or theft of a privileged credential. Experts have been exploring Active Directory infrastructure to identify key threats and establish best practices for keeping data safe. Attend this month’s webinar to learn more.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Are you developing a Java application and want to create Excel Spreadsheets? You have come to the right place, this article will describe how you can create Excel Spreadsheets from a Java Application. For the purposes of this article, I will be u…
In this post we will learn how to connect and configure Android Device (Smartphone etc.) with Android Studio. After that we will run a simple Hello World Program.
Video by: Michael
Viewers learn about how to reduce the potential repetitiveness of coding in main by developing methods to perform specific tasks for their program. Additionally, objects are introduced for the purpose of learning how to call methods in Java. Define …
This tutorial will introduce the viewer to VisualVM for the Java platform application. This video explains an example program and covers the Overview, Monitor, and Heap Dump tabs.

910 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

17 Experts available now in Live!

Get 1:1 Help Now