Sample code for 30+ languages & platforms
.NET Core C#

Load .eml and Examine the Structure, Attachments, and Related Items

See more Email Object Examples

Demonstrates how to load examine the MIME structure of a .eml, and also examine the attachment and related item filenames, attached messages, and multipart/report and DSN information.

Chilkat .NET Core C# Downloads

.NET Core C#
bool success = false;

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

string emlPath = "C:/AAWorkarea/beatrix/roesner.eml";

Chilkat.Mime mime = new Chilkat.Mime();

success = mime.LoadMimeFile(emlPath);
if (success == false) {
    Debug.WriteLine(mime.LastErrorText);
    return;
}

Debug.WriteLine("---- MIME structure ----");
Debug.WriteLine(mime.GetStructure("text"));
Debug.WriteLine("------------------------");

Chilkat.Email email = new Chilkat.Email();
success = email.LoadEml(emlPath);

// Was this a signed and/or encrypted email?
// If so, then loading the .eml automatically unwraps
// (i.e. verifies signatures and decrypts) and the resultant
// email is what existed prior to signing/encrypting.
Debug.WriteLine("Email was Signed: " + Convert.ToString(email.ReceivedSigned));
Debug.WriteLine("Email was Encrypted: " + Convert.ToString(email.ReceivedEncrypted));
if (email.ReceivedSigned == true) {
    Debug.WriteLine("Signature(s) valid = " + Convert.ToString(email.SignaturesValid));
}

if (email.ReceivedEncrypted == true) {
    Debug.WriteLine("Decrypted successfully = " + Convert.ToString(email.Decrypted));
}

int i = 0;
int numAttach = email.NumAttachments;
Debug.WriteLine("Number of attachments = " + Convert.ToString(numAttach));

while (i < numAttach) {
    Debug.WriteLine("---- Attachment " + Convert.ToString(i));

    // Examine the filename (if any)
    Debug.WriteLine("filename: " + email.GetAttachmentFilename(i));
    // Examine the content-ID (if any)
    Debug.WriteLine("Content-ID: " + email.GetAttachmentContentID(i));
    // Examine the content-type
    Debug.WriteLine("Content-Type: " + email.GetAttachmentContentType(i));
    // Examine the content-disposition
    Debug.WriteLine("Content-Disposition" + email.GetAttachmentHeader(i,"content-disposition"));
    // Examine the attachment size:
    Debug.WriteLine("Size (in bytes) of the attachment: " + Convert.ToString(email.GetAttachmentSize(i)));

    i = i + 1;
}

Debug.WriteLine("--");

// Now for the related items.

// Note: A MIME sub-part can potentially be both a related item AND an attachment.
// The typical case is when the item is contained under the multipart/related enclosure and 
// the item also has a "Content-Disposition" header indicating "attachment".
// The location within multipart/related makes it a "related item", yet the Content-Disposition can also make it semantically an attachment.
// Related items and attachments are not necessarily mutually exclusive.

int numRelated = email.NumRelatedItems;
Debug.WriteLine("Number of related items = " + Convert.ToString(numRelated));
i = 0;
while (i < numRelated) {
    Debug.WriteLine("---- Related Item " + Convert.ToString(i));

    // Examine the filename (if any)
    Debug.WriteLine("filename: " + email.GetRelatedFilename(i));
    // Examine the content-ID (if any)
    Debug.WriteLine("Content-ID: " + email.GetRelatedContentID(i));
    // Examine the content-type
    Debug.WriteLine("Content-Type: " + email.GetRelatedContentType(i));
    // Examine the content-location (if any)
    Debug.WriteLine("Content-Location" + email.GetRelatedContentLocation(i));

    i = i + 1;
}

// The email could also have attached messages.
// An attached message is another email that was attached to this email.
Chilkat.Email em = new Chilkat.Email();
int numAttachedMessages = email.NumAttachedMessages;
Debug.WriteLine("Number of attached messages = " + Convert.ToString(numAttachedMessages));
i = 0;
while (i < numAttachedMessages) {
    Debug.WriteLine("---- Attached message " + Convert.ToString(i));

    // Examine the attached email
    email.GetAttachedEmail(i,em);
    Debug.WriteLine("from: " + em.From);
    Debug.WriteLine("subject: " + em.Subject);
    i = i + 1;
}

// An email could also be a multipart/report email. 
// This is a DSN (Delivery Status Notification)
// The NumReports property indicates how many "reports" exist.
int numReports = email.NumReports;
Debug.WriteLine("Number of reports = " + Convert.ToString(numReports));
i = 0;
while (i < numReports) {
    Debug.WriteLine("---- Report " + Convert.ToString(i));
    // Get the raw report data...
    Debug.WriteLine(email.GetReport(i));
    i = i + 1;
}

// If the email is a multipart/report, then the information
// from the message/delivery-status part of the email can be retrieved:
if (email.IsMultipartReport() == true) {

    Debug.WriteLine("--- Delivery Status Information:");
    Debug.WriteLine("Status: " + email.GetDeliveryStatusInfo("Status"));
    Debug.WriteLine("Action: " + email.GetDeliveryStatusInfo("Action"));
    Debug.WriteLine("Reporting-MTA: " + email.GetDeliveryStatusInfo("Reporting-MTA"));

    Chilkat.JsonObject jsonDsnInfo = new Chilkat.JsonObject();
    email.GetDsnInfo(jsonDsnInfo);
    jsonDsnInfo.EmitCompact = false;
    Debug.WriteLine(jsonDsnInfo.Emit());
}