Visual C++ Examples

ChilkatHOMEAndroid™ASPVisual BasicVB.NETC#iOS (IPhone)Objective-CC++CUnicode C++Unicode CMFCDelphi DLLDelphi ActiveXFoxProJavaPerlPHP 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

 

 

 

 

 

 

 

 

Add DKIM-Signature Header to MIME / Email

Demonstrates how to add a DKIM-Signature header field to a MIME message.

Note: The DKIM / DomainKey functionality is included with the Chilkat MIME license.

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
FreeBSD C++ Libraries
HP-UX C++ Libraries
BlackBerry QNX C++ Libraries
#include <CkDkim.h>
#include <CkByteData.h>

void ChilkatSample(void)
    {
    //  Important: It is helpful to send the contents of the
    //  dkim.LastErrorText property when requesting support.

    CkDkim dkim;

    //  Any string automatically begins a fully-functional 30-day trial.
    bool success;
    success = dkim.UnlockComponent("Anything for 30-day trial");
    if (success != true) {
        printf("%s\n",dkim.lastErrorText());
        return;
    }

    //  To create a DKIM signature for email (i.e. MIME),
    //  you'll need to provide the following:
    //  (1) An RSA private key in any common file format.
    //  (2) The domain name (typically the same domain
    //  as the sender of an email).
    //  (3) A selector for the domain name -- an arbitrary string
    //  to identify the matching public key in DNS.

    //  To allow an email recipient to verify the DKIM signature via an
    //  external email client supporting DKIM or using other software,
    //  you will need to create a DNS record with the selector
    //  and matching public key.  This example does not provide
    //  information about DKIM DNS record creation.
    //  (Chilkat does not provide an API for creating DNS records.
    //  Creating the DKIM DNS record is something you would do
    //  manually.)

    //  Set the domain and selector:
    //  You'll need to provide your own values here..
    dkim.put_DkimDomain("chilkatsoft.com");
    dkim.put_DkimSelector("tuna");

    //  Load a private key from any common RSA private key
    //  format, such as DER, PKCS8, PEM, XML, etc.
    //  The LoadDkimPkFile method automatically detects
    //  the file format and reads it appropriately.
    //  If a password is not required, you'll still need to provide
    //  a password string argument, but it is ignored.
    const char * password;
    password = "optionalPassword";
    success = dkim.LoadDkimPkFile("myPrivateKey.pem",password);
    if (success != true) {
        printf("%s\n",dkim.lastErrorText());
        return;
    }

    //  Load a MIME file.
    CkByteData mimeData;

    success = mimeData.loadFile("testMessage.eml");
    if (success != true) {
        printf("Failed to load file.\n");
        return;
    }

    //  Sign it.  This adds the DKIM-Signature header and
    //  returns the new MIME with DKIM-Signature added.
    CkByteData dkimSignedMime;
    success = dkim.AddDkimSignature(mimeData,dkimSignedMime);
    if (success != true) {
        printf("%s\n",dkim.lastErrorText());
        return;
    }

    success = dkimSignedMime.saveFile("dkimSigned.eml");
    if (success != true) {
        printf("Failed to save file.\n");
        return;
    }

    printf("Success.\n");
    }

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