![]() |
Chilkat HOME Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi DLL Go Java Node.js Objective-C PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(C) Convert PEM to JKS (Java KeyStore)Converts a PEM containing private key(s) and certificates into a JKS (Java KeyStore) formatted file. Note: This example requires Chilkat v11.0.0 or greater.
#include <C_CkPem.h> #include <C_CkJavaKeyStore.h> void ChilkatSample(void) { BOOL success; HCkPem pem; const char *password; const char *pemContent; const char *alias; const char *jksPassword; HCkJavaKeyStore jks; success = FALSE; // This example requires the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. pem = CkPem_Create(); // Load the PEM from a file. // If the PEM is encrypted, provide a password. Otherwise pass an empty string for the password. password = "myPassword"; success = CkPem_LoadPemFile(pem,"../myPemFiles/myPem.pem",password); if (success == FALSE) { printf("%s\n",CkPem_lastErrorText(pem)); CkPem_Dispose(pem); return; } // Note: If the app already has the PEM pre-loaded in a string variable, then load it // by calling LoadPem instead. pemContent = "... the PEM contents ..."; success = CkPem_LoadPem(pem,pemContent,password); // Check for success as before.. // Convert to a JavaKeyStore object. // The alias, if a non-empty string, will be applied to the 1st private key or // certificate. All other keys and/or certificates will be assigned an auto-generated // alias. alias = "anything_I_want_here"; // This is the passord that will be required to access the created JKS. jksPassword = "myJksSecret"; jks = CkJavaKeyStore_Create(); success = CkPem_ToJksObj(pem,alias,jksPassword,jks); if (success == FALSE) { printf("%s\n",CkPem_lastErrorText(pem)); CkPem_Dispose(pem); CkJavaKeyStore_Dispose(jks); return; } // Save the JKS to a file. The password passed here is used for the keyed hash of the // entire JKS file. This may be different (if desired) than the password for individual private keys // contained within the JKS. success = CkJavaKeyStore_ToFile(jks,jksPassword,"../myJksFiles/myJks.jks"); if (success == FALSE) { printf("%s\n",CkJavaKeyStore_lastErrorText(jks)); CkPem_Dispose(pem); CkJavaKeyStore_Dispose(jks); return; } CkPem_Dispose(pem); CkJavaKeyStore_Dispose(jks); } |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.