Sample code for 30+ languages & platforms
Unicode C

Encrypt MIME using RSAES-OAEP with SHA256 and AES-128 content encryption

See more MIME Examples

Demonstrates how to encrypt MIME using RSAES-OAEP with SHA256 and AES-128 content encryption.

Note: This example requires Chilkat v9.5.0.67 or greater.

Chilkat Unicode C Downloads

Unicode C
#include <C_CkMimeW.h>
#include <C_CkStringBuilderW.h>
#include <C_CkCertW.h>

void ChilkatSample(void)
    {
    BOOL success;
    HCkMimeW mime;
    HCkMimeW part0;
    HCkMimeW part1;
    HCkStringBuilderW sbMime;
    HCkCertW cert;

    success = FALSE;

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

    mime = CkMimeW_Create();

    // Create a MIME message to encrypt.
    CkMimeW_NewMultipartMixed(mime);
    CkMimeW_AddHeaderField(mime,L"someHeader1",L"Some value 1");
    CkMimeW_AddHeaderField(mime,L"someHeader2",L"Some value 2");

    part0 = CkMimeW_Create();
    CkMimeW_AddHeaderField(part0,L"hdrA",L"Some value A");
    CkMimeW_AddHeaderField(part0,L"hdrB",L"Some value B");
    CkMimeW_putContentType(part0,L"text/plain");
    CkMimeW_SetBody(part0,L"This is the plain-text body.");

    part1 = CkMimeW_Create();
    CkMimeW_AddHeaderField(part1,L"hdrX",L"Some value X");
    CkMimeW_AddHeaderField(part1,L"hdrY",L"Some value Y");
    CkMimeW_putContentType(part1,L"text/xml");
    CkMimeW_SetBody(part1,L"<a>This is the XML body</a>");

    CkMimeW_AppendPart(mime,part0);
    CkMimeW_AppendPart(mime,part1);

    // The MIME to be encrypted:
    sbMime = CkStringBuilderW_Create();
    CkMimeW_GetMimeSb(mime,sbMime);
    wprintf(L"%s\n",CkStringBuilderW_getAsString(sbMime));

    // 	Content-Type: multipart/mixed; boundary="------------080303020600020604010008"
    // 	someHeader1: Some value 1
    // 	someHeader2: Some value 2
    // 
    // 	--------------080303020600020604010008
    // 	hdrA: Some value A
    // 	hdrB: Some value B
    // 	Content-Type: text/plain
    // 
    // 	This is the plain-text body.
    // 	--------------080303020600020604010008
    // 	hdrX: Some value X
    // 	hdrY: Some value Y
    // 	Content-Type: text/xml
    // 
    // 	<a>This is the XML body</a>
    // 	--------------080303020600020604010008--
    // 

    // Load an RSA-based certificate.
    // (Encrypting MIME only requires the public key.  Decrypting MIME requires the private key.)
    cert = CkCertW_Create();
    success = CkCertW_LoadFromFile(cert,L"qa_data/rsaes-oaep/cert.pem");
    if (success != TRUE) {
        wprintf(L"%s\n",CkCertW_lastErrorText(cert));
        CkMimeW_Dispose(mime);
        CkMimeW_Dispose(part0);
        CkMimeW_Dispose(part1);
        CkStringBuilderW_Dispose(sbMime);
        CkCertW_Dispose(cert);
        return;
    }

    // Set the email object properties to indicate the desired encryption.
    CkMimeW_putPkcs7CryptAlg(mime,L"aes");
    // If AES-256 is desired, set the following property to 256.
    CkMimeW_putPkcs7KeyLength(mime,128);
    CkMimeW_putOaepPadding(mime,TRUE);
    // Other choices for the OAEP hash algorithm are "sha1", "sha384", and "sha512"
    CkMimeW_putOaepHash(mime,L"sha256");

    // Encrypt the MIME (to create S/MIME, which stands for "Secure MIME")
    success = CkMimeW_Encrypt(mime,cert);
    if (success != TRUE) {
        wprintf(L"%s\n",CkMimeW_lastErrorText(mime));
        CkMimeW_Dispose(mime);
        CkMimeW_Dispose(part0);
        CkMimeW_Dispose(part1);
        CkStringBuilderW_Dispose(sbMime);
        CkCertW_Dispose(cert);
        return;
    }

    wprintf(L"---------------\n");
    wprintf(L"Encrypted MIME:\n");
    wprintf(L"---------------\n");
    wprintf(L"%s\n",CkMimeW_getMime(mime));

    wprintf(L"Success.\n");

    // ---------------------------------------------------
    // This is sample output for RSAES-OAEP encrypted MIME:
    // ---------------------------------------------------

    // Content-Type: application/x-pkcs7-mime; name="smime.p7m"; smime-type="enveloped-data"
    // someHeader1: Some value 1
    // someHeader2: Some value 2
    // Content-Disposition: attachment; filename="smime.p7m"
    // Content-Transfer-Encoding: base64
    // 
    // MIIDvAYJKoZIhvcNAQcDoIIDrTCCA6kCAQAxggGgMIIBnAIBADB1MGgxCzAJBgNVBAYTAlVTMQsw
    // CQYDVQQIDAJJTDEQMA4GA1UEBwwHV2hlYXRvbjEhMB8GA1UECgwYSW50ZXJuZXQgV2lkZ2l0cyBQ
    // dHkgTHRkMRcwFQYDVQQDDA5DaGlsa2F0V2lkZ2V0cwIJAMRwugDmvniwMBwGCSqGSIb3DQEBBzAP
    // oA0wCwYJYIZIAWUDBAIBBIIBAFaUL1ga1bOrdqYKcMm+FHUacBvzfBxk0fnPA0AMBdN8BvTWT3CN
    // YuqBhjOGyq0FpYD9pVZybUuFMCVsVyIW2O62HnsOK58YaPEUUcdH2sI+yjqX9UAn0P0nVDSsVdeK
    // W8x9kMfZg+3UP+y1q+lu7VRJO3f2C9oLQpTkc4VW4n7UOcUI0waykLCjCTL8lFDb7/J3GeuMKyhH
    // 5riNz50kpbzqn7m2Ks9yA+QmcTdXclclGFr2vwEUFzSdT2pxh/vaUrogCxkYWbQ2eV7vZg6O4kV0
    // aqHBqySkPTAzHKiHH8K8GVdlTuJ8350CpICa4T8w7/Ht5I7dyOPPKy4C+rVtrvcwggH+BgkqhkiG
    // 9w0BBwEwHQYJYIZIAWUDBAECBBDTC2WNBN+z2I47/4Feu9YqgIIB0MZvl3nC/q/Wzil6HtfQTr12
    // Q5moHY+ORzAa1P9XvX2ZUFhW530mV395mQw/A4o4ekmX9eRPEZquYzZPLT8hNeZIuNdhpcSQUmad
    // rKnKkR0wKJ3jJ3LhOIohVBQSYs8kVDZKq6lJBIznlsurFelZoNEhyRschhteDZx5rb7fCe8c2+/O
    // DHxaqaHCAzm/Bd7kcg6FFfuTZy3tu0PgP5IsXN4OFA3kkvwjAs4XsVS8jdIcmDNBkYieE8WmJOIm
    // Mz7mh/CHWLgWfGKa0Dkb9RcbFgLwYNT3GzuXFw9XPbKkEZjEAtJajWbN6P0WQl96YYd9qZxUpGxZ
    // zjTHEYzViUdUXolfpLufttrRXyxN1RFWhNFMFbv66xYqklMSgpdM/Mbk+EuvX6eXayDPvDBpfYMw
    // NoRAzv1Ony2c0ez9rBemJICicxAzpuvHbRxdjYs63Dnv+TYgpBK12AxWWpPIjXvw0WQKgTC3Tg8s
    // EnuGhpENqso/clJBEBSn4+2WhYtYbdI5sVme67lvqQl1Xxy3r18SWaQbyDOwgYi1E+54lMDOxMy0
    // y0FPHk5pP45DnXWj+XORPp5LhuZr5mf62YOXSSUwR5P0cXy4Rc+pN5lhRQPCf5z2


    CkMimeW_Dispose(mime);
    CkMimeW_Dispose(part0);
    CkMimeW_Dispose(part1);
    CkStringBuilderW_Dispose(sbMime);
    CkCertW_Dispose(cert);

    }