Swift
Swift
Change Password for Java KeyStore File
See more Java KeyStore (JKS) Examples
Demonstrates how to load a Java keystore, change the password, and save using the new password. If the Java keystore contains only trusted root certificates, then it's simply a matter of loading the JKS with the existing password, and then saving with a new password. If the JKS contains private key entries, then each private key entry must be re-keyed using the new password by calling the ChangePassword method.Chilkat Swift Downloads
func chilkatTest() {
var success: Bool = false
// This requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
let jks = CkoJavaKeyStore()!
var oldJksPassword: String? = "existingPassword"
var newJksPassword: String? = "newPassword"
var jksPath: String? = "/someDir/keyStore.jks"
// Load the Java keystore from a file.
success = jks.loadFile(password: oldJksPassword, path: jksPath)
if success != true {
print("\(jks.lastErrorText!)")
return
}
// If the JKS contains private key entries, then each
// must be re-keyed with the new password by calling ChangePassword.
var numPrivateKeys: Int = jks.numPrivateKeys.intValue
var i: Int = 0
while i < numPrivateKeys {
success = jks.changePassword(index: i, oldPassword: oldJksPassword, newPassword: newJksPassword)
if success != true {
print("\(jks.lastErrorText!)")
return
}
i = i + 1
}
// Write the JKS using the new password for the JKS file's keyed digest.
success = jks.toFile(password: newJksPassword, path: jksPath)
if success != true {
print("\(jks.lastErrorText!)")
return
}
print("Updated the password for the Java keystore file.")
}