Sample code for 30+ languages & platforms
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

Unicode C++
#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");
    }