Sample code for 30+ languages & platforms
C++

DKIM Signature using Windows Current User Certificate Store

See more DKIM / DomainKey Examples

This is a Windows-specific example to load a certificate from the Current User (registry-based) certificate store, and then use the certificate's associated private key for a DKIM signature.

Chilkat C++ Downloads

C++
#include <CkCert.h>
#include <CkPrivateKey.h>
#include <CkDkim.h>

void ChilkatSample(void)
    {
    bool success = false;

    // This example requires the Chilkat API to have been previously unlocked.
    // See Global Unlock Sample for sample code.

    CkCert cert;

    // The LoadByCommonName method searches the Windows Local Machine and Current User 
    // registry-based certificate stores for a certificate having the common name specified. 
    // If found, the certificate is loaded and ready for use.
    success = cert.LoadByCommonName("My Certificate ABC");
    if (success == false) {
        std::cout << cert.lastErrorText() << "\r\n";
        return;
    }

    // The certificate must have an associated private key installed, and it must be a
    // private key that has been marked "exportable" when it was originally installed.
    if (!cert.HasPrivateKey()) {
        std::cout << "This certificate does not have a private key available." << "\r\n";
        return;
    }

    CkPrivateKey privKey;
    success = cert.GetPrivateKey(privKey);
    if (success == false) {
        std::cout << cert.lastErrorText() << "\r\n";
        return;
    }

    CkDkim dkim;

    // Load the private key into the DKIM object:
    success = dkim.SetDkimPrivateKey(privKey);
    if (success == false) {
        std::cout << dkim.lastErrorText() << "\r\n";
        return;
    }

    // The private key has been loaded into the DKIM object.  See the other DKIM
    // examples for guidance on how to create a DKIM signature...
    }