Generating a new SSL certificate and key on a ProtectServer 3 HSM
To integrate Apache Tomcat with a ProtectServer 3 HSM by generating a new SSL certificate, you must complete the following steps:
Configuring Java for a ProtectServer 3 HSM
Tomcat uses Java JSSE for SSL/TLS support. Configure Java to add support for PKCS#11 that will be consumed by Tomcat for securing the SSL keys and certificates on the ProtectServer 3 HSM.
To configure PKCS#11 in Java
-
Log on to the Apache Tomcat server as root or as another user with administrative privileges.
-
Ensure that the JAVA_HOME and PATH variables are set.
Note
On Windows, set the JAVA_HOME and PATH System variables under System > Advanced system settings > Environment Variables…
-
Edit the Java Security Configuration file (java.security) located in <JDK_installation_directory>/jre/lib/security and add PKCS#11 to the java.security file.
Note
On Windows, the java.security file is located in <JDK_installation_directory>\jre\lib\security.
Generating key materials on the ProtectServer 3 HSM
When Java is configured to use PKCS#11, we can create the keys and certificate in the keystore pointing to ProtectServer 3 HSM slot.
To create keys and certificate in a ProtectServer 3 HSM
-
Generate a key pair in the keystore using the Java keytool utility. The key pair will be generated on the registered slot of the ProtectServer 3 HSM.
For example:
-
Display the generated key materials.
For example:
Configuring SSL for Apache Tomcat
The Apache Tomcat server uses the SSL key and certificate stored in the keystore for SSL communication.
Apache Tomcat uses the server.xml file available in <Tomcat_installation_directory>/conf to define the connector setting for SSL.
Note
On Windows, server.xlm is located in <Tomcat_installation_directory>\conf.
To configure SSL for Apache Tomcat
-
Stop the server, if running. Run the shutdown.bat or shutdown.sh script provided under bin folder of <Tomcat_installation_directory>.
-
Edit server.xml by uncommenting the existing connector and updating it as shown in the snippets below or by adding the snippets shown below in their entirety without uncommenting the existing one.
For Apache Tomcat 9
For Apache Tomcat 10
Save and close server.xml.
Ensure that the keystore settings values are correct as per your environment.
-
Start the Tomcat server using startup.bat or startup.sh provided under bin directory of <Tomcat_installation_directory>.
-
If Tomcat starts successfully, you will see the default page of Tomcat at https://<hostname or IP address>:8443/. The SSL certificate is the one that you generated and stored in PTK Keystore.
This completes the Apache Tomcat integration with the ProtectServer 3 HSM.
The SSL certificate private key is secured on the HSM slot and the SSL page will be accessible only if the HSM slot is accessible and available to Apache Tomcat Server.