Visual C++ Examples

ChilkatHOMEAndroid™ASPVisual BasicVB.NETC#iOS (IPhone)Objective-CC++CMFCDelphiFoxProJavaPerl
PHP ExtensionPHP ActiveXPythonPowerShellRubySQL ServerVBScript

C++ Examples

CkString
Byte Array
Bounced Mail
Bz2
Character Encoding
CSV
DH Key Exchange
DKIM/DomainKeys
Digital Certificates
Digital Signatures
DSA
Email
Email Object
Encryption
FTP
HTML Conversion
HTTP
IMAP
MHT / HTML Email
POP3
RSA
S/MIME
SMTP
Socket
Spider
SSH Key
SSH
SSH Tunnel
SFTP
Tar
Upload
XML
XMP
Zip Compression


More Examples...
Amazon S3
NTLM
FileAccess
RSS
Atom
Self-Extractor
Service
PPMD
Deflate
Bzip2
LZW

 

 

 

 

 

 

 

 

Export Certificate and Private Key to PFX

Downloads:

MS Windows Visual C/C++ Libraries
Linux/CentOS C/C++ Libraries
MAC OS X C/C++ Libraries
Solaris C/C++ Libraries
C++ Builder Libraries

Demonstrates how to export a digital certificate, it's private key, and potentially all certificates in the chain of authentication to a PFX file.

#include <CkCreateCS.h>
#include <CkCertStore.h>
#include <CkCert.h>

void ChilkatSample(void)
    {
    bool success;

    //  This object is used to create a certificate store object.
    CkCreateCS ccs;

    CkCertStore *certStore = 0;
    //  Open the local machine certificate store read-only.
    ccs.put_ReadOnly(true);
    certStore = ccs.OpenLocalSystemStore();

    //  Can we find a certificate by email address?
    CkCert *cert = 0;
    cert = certStore->FindCertBySubjectE("admin@chilkatsoft.com");
    if (cert == 0 ) {
        //  Open the current-user certificate store and check it instead.
        delete certStore;
        printf("Checking current-user certificate store...\n");

        certStore = ccs.OpenCurrentUserStore();

        cert = certStore->FindCertBySubjectE("admin@chilkatsoft.com");
        if (cert == 0 ) {
            printf("Failed to find certificate!\n");
            return;
        }

    }

    delete certStore;

    //  Does this certificate have a private key accessible
    //  to the calling process?  Private keys are *not* stored
    //  within the certificate store.  Private keys are stored
    //  in a key container in a Windows protected store.  It
    //  can be one of two protected stores: the protected store for
    //  the current logged-in user account, or the "machine-key"
    //  protected store.  The private key must both exist in a
    //  protected store, and the process must have permission to
    //  access it...

    //  You can only export to a PFX if the private key exists
    //  and is accessible.

    if (cert->HasPrivateKey() == true) {

        //  Export to a PFX.
        //  Provide a password that will be required whenever the PFX is opened.
        //  Also, include all certs in the chain of authentication.
        bool bIncludeChain;
        bIncludeChain = true;
        success = cert->ExportToPfxFile("myCert.pfx","myPassword",bIncludeChain);
        if (success != true) {
            printf("%s\n",cert->lastErrorText());
        }
        else {
            printf("Exported to PFX!\n");
        }

    }
    else {
        printf("Certificate does not have a private key available\n");
    }

    delete cert;

    //  The Chilkat Certificate, Certificate Store, Private Key,
    //  Public Key, and Key Container classes / objects are freeware.

    //  They are used by and included with the Chilkat Email,
    //  Crypt, S/MIME, and other commercial Chilkat components.

    }

© 2000-2010 Chilkat Software, Inc. All Rights Reserved.

Mail Component · .NET Mail Component · XML Parser