Struggling how create a Java deployment ruleset? You’ve come to the right place. Here’s a step-by-step tutorial on how it’s done.
This particular task almost put me in the grave. The request was simple. Silence Java security prompts for a couple of web applications. Sounds easy enough, right?
Hell no it wasn’t!
..at least not when attempting to sign the ruleset with an Active Directory Certificate Services certificate. After a ton of Googling around and trial and error I gave up and decided to just go with the self-signed cert. I know this isn’t the most secure way to do this but I’ve given up and once I did, it worked like a charm.
If you do want to try to use an ADCS certificate, a blog post entitled Deploying a Java DeploymentRuleSet.Jar using a Active Directory Certificate Services cert that I found may help you.
Here’s the steps I took to create and deploy a Java Deployment RuleSet to my clients.
- Create your ruleset.xml file.
- Download and install the JDK on your admin workstation.
- Copy ruleset.xml to the JDK install folder C:\Program Files\Java\jdk1.X.X_X\bin
- Change to the JDK install folder’s bin directory.
- Run the command:
jar -cvf DeploymentRuleSet.jar ruleset.xml
- Run the command:
keytool.exe -genkey -alias SelfSigned -keystore "SelfSigned.jks" -keyalg RSA -keysize 2048 -startdate "2000/01/01 00:00:00" -validity 18262
answering the prompts, type “yes” to trust the cert and use the same password as the keystore password. - Run the command:
keytool.exe -export -file "SelfSigned.cer" -alias SelfSigned -keystore "SelfSigned.jks"
- Run the command:
jarsigner.exe -keystore "SelfSigned.jks" -signedjar "DeploymentRuleSet.jar" DeploymentRuleSet.jar SelfSigned
- Copy the DeploymentRuleSet.jar file to your clients’ C:\Windows\Sun\Java\Deployment folder.
- Copy the C:\Users\<THE USER YOU’RE LOGGED IN WITH>\AppData\LocalLow\Sun\Java\Deployment\security\trusted.certs file to your clients’ C:\Windows\Sun\Java\Deployment folder.
- Give Authenticated Users Modify rights on your clients’ C:\Windows\Sun\Java\Deployment folder.
- Copy the SelfSigned.cert certificate to your client somewhere.
- Import the SelfSigned.cert certificate in your client’s Trusted Root Certification Authorities certificate store.
- Verify you have an active deployment rule set in the Java Control Panel on your client like this screenshot.
data:image/s3,"s3://crabby-images/d2b9c/d2b9cfbf152b45dbb9b418de81fa9c2334700877" alt="Viewing a Java Active Deployment Rule set"
15. Try your web site again and confirm the security prompt is gone!