Programming Examples

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

C Examples

Bounced Mail
Bz2
Certificates/Keys
Charset
CSV
DKIM / DomainKey
Diffie-Hellman
DSA
Email Object
Encryption
FileAccess
FTP
HTML Conversion
HTTP
IMAP
MHT / HTML Email
MIME
NTLM
POP3
RSA
SMTP
Socket
Spider
SSH Key
SSH
SSH Tunnel
SFTP
Tar
Upload
XML
Zip
Amazon S3

 

 

 

 

 

 

 

 

Add DomainKey-Signature Header to MIME / Email

Demonstrates how to add a DomainKey-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
#include <C_CkDkim.h>
#include <C_CkByteData.h>

void ChilkatSample(void)
    {
    HCkDkim dkim;
    BOOL success;
    const char * password;
    HCkByteData mimeData;
    HCkByteData domainKeySignedMime;

    //  Important: It is helpful to send the contents of the
    //  dkim.LastErrorText property when requesting support.

    dkim = CkDkim_Create();

    //  Any string automatically begins a fully-functional 30-day trial.

    success = CkDkim_UnlockComponent(dkim,"Anything for 30-day trial");
    if (success != TRUE) {
        printf("%s\n",CkDkim_lastErrorText(dkim));
        return;
    }

    //  To create a DomainKey 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 DomainKey signature via an
    //  external email client supporting DomainKey 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 DomainKey DNS record creation.
    //  (Chilkat does not provide an API for creating DNS records.
    //  Creating the DomainKey DNS record is something you would do
    //  manually.)

    //  Set the domain and selector:
    //  You'll need to provide your own values here..
    CkDkim_putDomainKeyDomain(dkim,"chilkatsoft.com");
    CkDkim_putDomainKeySelector(dkim,"salmon");

    //  Load a private key from any common RSA private key
    //  format, such as DER, PKCS8, PEM, XML, etc.
    //  The LoadDomainKeyPkFile 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.

    password = "optionalPassword";
    success = CkDkim_LoadDomainKeyPkFile(dkim,"myPrivateKey.pem",password);
    if (success != TRUE) {
        printf("%s\n",CkDkim_lastErrorText(dkim));
        return;
    }

    //  Load a MIME file.
    mimeData = CkByteData_Create();

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

    //  Sign it.  This adds the DomainKey-Signature header and
    //  returns the new MIME with DomainKey-Signature added.
    domainKeySignedMime = CkByteData_Create();
    success = CkDkim_AddDomainKeySignature(dkim,mimeData,domainKeySignedMime);
    if (success != TRUE) {
        printf("%s\n",CkDkim_lastErrorText(dkim));
        return;
    }

    success = CkByteData_saveFile(domainKeySignedMime,"domainKeySigned.eml");
    if (success != TRUE) {
        printf("Failed to save file.\n");
        return;
    }

    printf("Success.\n");

    CkDkim_Dispose(dkim);
    CkByteData_Dispose(mimeData);
    CkByteData_Dispose(domainKeySignedMime);

    }

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

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