Token Based JAR Signing in Mac OS X Environments
Feb 21, 2024
Introduction
This article provides step-by-step instructions for Token Based JAR Signing in MAC OS X Environments. If you are looking for a different solution, please use the search bar above.
Process
Configuring JDK
-
Install the 32-bit JDK and locate the JDK bin folder. Note: The default location is "Computer\Mac OS X\Library\Java\JavaVirtualMachine\jdkx.x.x_xxx\Contents\Home\bin".
data:image/s3,"s3://crabby-images/11dcb/11dcbc8526a8a846e6dba768b2e1c743f2457ebf" alt="pic_1.jpg"
- Using sublime text or another text editor that supports multiple file formats, create a file named eToken.cfg in the bin folder with the following content as shown below.
data:image/s3,"s3://crabby-images/4f8c2/4f8c2080235f0426b7a9b6a42f8231a0f1e8e74b" alt="pic_2.jpg"
- Save the eToken.cfg in the bin folder.
- Right-click the bin folder, and click Get Info.
- Click the padlock at the bottom right, then change the permissions so you can read and write on that folder.
data:image/s3,"s3://crabby-images/0d915/0d9159e5c78024e4e80776dbbf045a61c02b05fb" alt="pic_5.jpg"
MAC OS X JarSigning
- Open the terminal and then navigate to the jdkx.x.x_xxx\bin directory where jarsigner.exe, keytool.exe, and the eToken.cfg file you created are located.
data:image/s3,"s3://crabby-images/5db89/5db8938efa629dd9d21cce85c11837c05d6b588a" alt="mac1.jpg"
- Confirm your certificate alias with the terminal command:
keytool -list -keystore NONE -storetype PKCS11 -providerclass sun.security.pkcs11.SunPKCS11 -providerArg eToken.cfg
data:image/s3,"s3://crabby-images/94b3f/94b3f953f248237b83ddad78f59e56faf50efd19" alt="mac_2.jpg"
Enter your keystore passphrase (token password) when prompted.
- Sign the JAR file using the following command:
jarsigner -tsa http://timestamp.globalsign.com/tsa/r6advanced1 -storetype PKCS11 -providerClass sun.security.pkcs11.SunPKCS11 -providerArg eToken.cfg /directory/test.jar "certificateAlias"
Enter your keystore passphrase (token password) when prompted. Wait for the output, "jar signed".
data:image/s3,"s3://crabby-images/f4d5d/f4d5d10af1dc03e1c7dc8203fa8070c93b66cfa5" alt="mac_3.jpg"
- Verify the signature by using the following command:
jarsigner -verify -verbose /directory/test.jar
You should be getting an output similar to the image below with "jar verified" at the end.
data:image/s3,"s3://crabby-images/9e16c/9e16c4ac5e2aa538975cd97bde29c55050d81d16" alt="mac_4.jpg"