Visual C++ Examples

ChilkatHOMEASPVisual BasicVB.NETC#Visual C++CMFCDelphiFoxProJavaPerlPHPPythonRubySQL ServerVBScript

Visual C++ Examples

CkString
Byte Array
Bounced Mail
Character Encoding
Digital Certificates
Digital Signatures
Email
Encryption
FTP
HTML-to-XML
HTTP
IMAP
MHT / HTML Email
RSA Encryption
S/MIME
Socket
Spider
Tar
Upload
XML
XMP
Zip Compression


More Examples...
Email Object
POP3
SMTP
RSS
Atom
Self-Extractor

Unreleased...
Service
PPMD
Deflate
Bzip2
LZW
Bz2
DH Key Exchange
DSA
Icon

 

 

 

 

 

 

 

 

Export Certificate and Private Key to PFX

Download Chilkat C/C++ Libraries for VC++ 9.0 / Win32

Download Chilkat C/C++ Libraries for VC++ 8.0 / Win32

Download Chilkat C/C++ 64-bit Libraries for VC++ 8.0 / x64

Download Chilkat Visual Studio 2005 C/C++ Libs for Windows Mobile, Pocket PC, SmartPhone, WinCE

Download Chilkat C/C++ Libraries for VC++ 7.0 / Win32

Download Chilkat C/C++ Libraries for VC++ 6.0 / Win32

Download Chilkat C/C++ Libraries for VC++ 6.0, Win 95/98/NT4 Compatible

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.

    }

Need a specific example? Send a request to support@chilkatsoft.com

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

Mail Component · .NET Mail Component · XML Parser