Unicode C++
Unicode C++
Duplicate openssl pkcs12 –export –in certfile.cer –inkey certfile.key –out certfile.pfx
See more OpenSSL Examples
How to create a PKCS12 (.p12 or .pfx) from a certificate file and private key file: Demonstrates how to duplicate this OpenSSL command:Duplicate openssl pkcs12 –export –in certfile.cer –inkey certfile.key –out certfile.pfx
Chilkat Unicode C++ Downloads
#include <CkPrivateKeyW.h>
#include <CkCertW.h>
#include <CkCertChainW.h>
#include <CkPfxW.h>
void ChilkatSample(void)
{
bool success = false;
// This example assumes the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
CkPrivateKeyW pkey;
// Load the private key from the file.
success = pkey.LoadAnyFormatFile(L"certFile.key",L"");
if (success != true) {
wprintf(L"%s\n",pkey.lastErrorText());
return;
}
CkCertW cert;
// The LoadFromFile method auto-recognizes the format...
success = cert.LoadFromFile(L"certfile.cer");
if (success != true) {
wprintf(L"%s\n",cert.lastErrorText());
return;
}
// We'll need a cert chain object to create the PKCS12, so get it
// from the cert.
CkCertChainW *certChain = 0;
certChain = cert.GetCertChain();
if (!cert.get_LastMethodSuccess()) {
wprintf(L"%s\n",cert.lastErrorText());
return;
}
// Create the PFX object, add the cert and private key, and write to a .pfx file.
CkPfxW pfx;
// The cert(s) are automatically added in the call to AddPrivateKey
success = pfx.AddPrivateKey(pkey,*certChain);
if (success != true) {
wprintf(L"%s\n",pfx.lastErrorText());
return;
}
// Write the .pfx to a file.
const wchar_t *password = L"myPassword";
success = pfx.ToFile(password,L"certfile.pfx");
if (success != true) {
wprintf(L"%s\n",pfx.lastErrorText());
return;
}
wprintf(L"Success.\n");
}