'Importing SSL Certificate into Eclipse
How do you import an SSL certificate created by java into a project in Eclipse?
Solution 1:[1]
In case you have the certificate already in your Windows' certificate store (this is common in corporate/company deployments with MITM certificates), you can also use the following steps (with help from another Stackoverflow answer with more detailed explaination):
Locate the
eclipse.inifile in your Eclipse installation and open itBelow the line
-vmargs, add the following lines, then save the file:
-Djavax.net.ssl.trustStore=NUL
-Djavax.net.ssl.trustStoreType=Windows-ROOT
- Restart eclipse.
Solution 2:[2]
There's a better tool for the job.
When you run (run as administrator in windows in order to save changes to system, sudo in linux, etc.) the application (it has installers for win/mac/linux) there's a built-in function to edit the system's cacerts file:
File -> Open Special -> Open CA Certificates
EITHER you already have the certificate file and you can go to:
Tools -> Import Trusted Certificate
OR you need to download the certificate from the server; go to:
Examine -> Examine SSL
From there type in the hostname and click ok. It will pop up a window showing the certificate details. At the bottom of that window there's an "Import" button that will allow you to directly import it into the cacerts.
Make sure you save and close cacerts, and restart your eclipse/application for the settings to take effect.
Solution 3:[3]
We need to import a certificate means we need to use :
keytool
-importcert
-file <certificate_location>
-keystore <jre_location\lib\security\cacerts>
-alias "<cert_name>"
It will ask for a password. Type the password as changeit
Type Password : changeit
finally it will ask need to add {yes/no} :
type yes.
Note: Don't give blank space in location path
Solution 4:[4]
Mac
- Open Keychain Access.app (Shortcut: press Command + Spacebar and type Keychain)
- Search the desired certificate file (e.g.
example.cer) and right-click ?? Select Export... ?? Save it to some location e.g.Desktop. - Follow the instructions in this answer to import it to your Java certificate store. The important commands are:
cd $JAVA_HOME/lib/security
sudo cp cacerts cacerts.bak
sudo keytool -importcert -alias youralias -file ~/Desktop/example.cer -keystore cacerts
The default password of the keystore is: changeit.
- Assuming,
$JAVA_HOME/lib/securitypoints to/Library/Java/JavaVirtualMachines/adoptopenjdk-15.jdk/Contents/Home/lib/securityin your system, add the following lines in theeclipse.inifile:
-Djavax.net.ssl.trustStore=/Library/Java/JavaVirtualMachines/adoptopenjdk-15.jdk/Contents/Home/lib/security/cacerts
-Djavax.net.ssl.trustStorePassword=changeit
Note: If you are using STS, follow this answer to locate the .ini file.
- Restart Eclipse.
Solution 5:[5]
If you have default Java setup and have provided Java classpath, then you must be using Java Truststore for SSL certificates.
For this you can follow below steps to import certificates into Trust store:
- Navigate to the JRE\bin folder of your Java setup Ideally the path should be:
user\Java\jre1.8.0_221\bin
- You will be able to find Keytool in the bin folder(which will be used to run the commands):
- Now once you are on this path, open the path in your CMD prompt:
- Now you will be able to find default Trust store of Java at below path: Path-
user\Java\jre1.8.0_221\bin
Path to Java default Trust store
Now you can run below command to see contents of this Trust store:
keytool -list -v -keystore "C:\Program Files\Java\jre1.8.0_221\lib\security\cacerts"
Note: If your path to Trust store has spaces in it, then you need to use double quotes for the path. Else you can provide path like below:
keytool -list -v -keystore C:\Temp\Java\jre1.8.0_221\lib\security\cacerts
Now just provide password to Trust Store(Default password is: changeit): Accessing Trust store using Keytool
You can now as per your need add any certificate to the Trust store:
JRE_HOME/bin/keytool -import -trustcacerts -alias certAlias -file certFile -keystore trustStoreFile
Solution 6:[6]
You should probably create the certificate and import it into the default keystore using keytool. I'm not sure what you're trying to do with your application, but it should then be able to use that certificate.
Solution 7:[7]
sudo keytool -import -file /Users/balaji-pt2176/Desktop/Apple\ Worldwide\ Developer\ Relations\ Certification\ Authority.cer -keystore /Library/Java/JavaVirtualMachines/jdk1.8.0_181.jdk/Contents/Home/jre/lib/security/cacerts
in mac
Sources
This article follows the attribution requirements of Stack Overflow and is licensed under CC BY-SA 3.0.
Source: Stack Overflow
| Solution | Source |
|---|---|
| Solution 1 | |
| Solution 2 | |
| Solution 3 | Stephen Rauch |
| Solution 4 | Arvind Kumar Avinash |
| Solution 5 | k.a. |
| Solution 6 | Jon |
| Solution 7 | Suraj Rao |




