Unicode C++
Unicode C++
Convert PEM to JKS (Java KeyStore)
See more PEM Examples
Converts a PEM containing private key(s) and certificates into a JKS (Java KeyStore) formatted file.Chilkat Unicode C++ Downloads
#include <CkPemW.h>
#include <CkJavaKeyStoreW.h>
void ChilkatSample(void)
{
bool success = false;
// This example requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
CkPemW pem;
// Load the PEM from a file.
// If the PEM is encrypted, provide a password. Otherwise pass an empty string for the password.
const wchar_t *password = L"myPassword";
success = pem.LoadPemFile(L"../myPemFiles/myPem.pem",password);
if (success == false) {
wprintf(L"%s\n",pem.lastErrorText());
return;
}
// Note: If the app already has the PEM pre-loaded in a string variable, then load it
// by calling LoadPem instead.
const wchar_t *pemContent = L"... the PEM contents ...";
success = pem.LoadPem(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.
const wchar_t *alias = L"anything_I_want_here";
// This is the passord that will be required to access the created JKS.
const wchar_t *jksPassword = L"myJksSecret";
CkJavaKeyStoreW jks;
success = pem.ToJksObj(alias,jksPassword,jks);
if (success == false) {
wprintf(L"%s\n",pem.lastErrorText());
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 = jks.ToFile(jksPassword,L"../myJksFiles/myJks.jks");
if (success == false) {
wprintf(L"%s\n",jks.lastErrorText());
return;
}
}