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

 

 

 

 

 

 

 

 

Verify S/MIME Signature

C++ example to verify an S/MIME signature and unwrap the S/MIME to get the original MIME prior to signing/encrypting.

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

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

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

#include <CkMime.h>
#include <CkCert.h>

void ChilkatSample(void)
    {
    CkMime mime;

    //  Any string argument automatically begins the 30-day trial.
    bool success;
    success = mime.UnlockComponent("30-day trial");
    if (success != true) {
        printf("MIME component unlock failed\n");
        return;
    }

    //  Load an S/MIME message from a file:
    success = mime.LoadMimeFile("signedMime.txt");
    if (success != true) {
        printf("%s\n",mime.lastErrorText());
        return;
    }

    //  The ContainsEncryptedParts/ContainsSignedParts methods
    //  can be called to determine if the MIME is encrypted and/or signed:
    bool isEncrypted;
    isEncrypted = mime.ContainsEncryptedParts();
    bool isSigned;
    isSigned = mime.ContainsSignedParts();

    //  We don't want the "unwrap extras".  You'll see what those
    //  are in a few moments...
    mime.put_UnwrapExtras(false);

    //  To verify the signature, call UnwrapSecurity.  This will
    //  verify the signature(s) and decrypt the S/MIME and restore
    //  the MIME to the unsigned/unencrypted state.
    //  The results of what was found are present in the MIME object's
    //  properties, as well as extra header fields that are added
    //  to the unwrapped MIME.
    success = mime.UnwrapSecurity();
    if (success != true) {
        //  UnwrapSecurity returns _TRUE_ if all signatures were
        //  verified and all parts decrypted.
        printf("%s\n",mime.lastErrorText());
        return;
    }

    //  The mime.UnwrapExtras property controls whether or not
    //  these additional fields are added to the unwrapped MIME:
    // 
    //  X-NumPartsSigned: 1
    //  X-SignaturesValid: yes
    //  X-NumPartsEncrypted: 1
    //  X-Decrypted: no
    // 
    //  The X-NumPartsSigned/X-SignaturesValid headers are added
    //  if the MIME was signed.
    // 
    //  The X-NumPartsEncrypted/X-Decrypted headers are added
    //  if the MIME was encrypted.
    // 

    //  If the MIME was signed, get the certificate used for signing.
    if (isSigned == true) {
        //  The NumSignerCerts property indicates how many certificates
        //  were used for signing.  This example will assume the value is 1.
        //  To get the 1st signer cert, call GetSignerCert with an index of 0:
        CkCert *signerCert = 0;
        signerCert = mime.GetSignerCert(0);
        if (!(signerCert == 0 )) {
            printf("**** Signer Cert: %s\n",signerCert->subjectCN());
        }

    }

    //  If the MIME was encrypted, get the certificate used for encryption:
    if (isEncrypted == true) {
        //  The NumEncryptCerts property indicates how many certificates
        //  were used for encrypting.  This example will assume the value is 1.
        //  To get the 1st encrypt cert, call GetEncryptCert with an index of 0:
        CkCert *encryptCert = 0;
        encryptCert = mime.GetEncryptCert(0);
        if (!(encryptCert == 0 )) {
            printf("**** Encrypt Cert: %s\n"
                ,encryptCert->subjectCN());
        }

    }

    //  Display the unwrapped MIME:
    printf("%s\n",mime.getMime());

    //  Save the unwrapped MIME to a file:
    mime.SaveMime("unwrappedMime.txt");


    }

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