Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Unicode C) Convert PEM to JKS (Java KeyStore)Converts a PEM containing private key(s) and certificates into a JKS (Java KeyStore) formatted file.
#include <C_CkPemW.h> #include <C_CkJavaKeyStoreW.h> void ChilkatSample(void) { HCkPemW pem; const wchar_t *password; BOOL success; const wchar_t *pemContent; const wchar_t *alias; const wchar_t *jksPassword; HCkJavaKeyStoreW jks; // This example requires the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. // The Chilkat PEM class was introduced in v9.5.0.49. // It requires the bundle to be unlocked, as shown above. pem = CkPemW_Create(); // Load the PEM from a file. // If the PEM is encrypted, provide a password. Otherwise pass an empty string for the password. password = L"myPassword"; success = CkPemW_LoadPemFile(pem,L"../myPemFiles/myPem.pem",password); if (success != TRUE) { wprintf(L"%s\n",CkPemW_lastErrorText(pem)); CkPemW_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 = L"... the PEM contents ..."; success = CkPemW_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 = L"anything_I_want_here"; // This is the passord that will be required to access the created JKS. jksPassword = L"myJksSecret"; jks = CkPemW_ToJks(pem,alias,jksPassword); if (CkPemW_getLastMethodSuccess(pem) == FALSE) { wprintf(L"%s\n",CkPemW_lastErrorText(pem)); CkPemW_Dispose(pem); 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 = CkJavaKeyStoreW_ToFile(jks,jksPassword,L"../myJksFiles/myJks.jks"); if (success != TRUE) { wprintf(L"%s\n",CkJavaKeyStoreW_lastErrorText(jks)); CkPemW_Dispose(pem); return; } CkJavaKeyStoreW_Dispose(jks); CkPemW_Dispose(pem); } |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.