Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(VBScript) Load .eml and Examine the Structure, Attachments, and Related ItemsDemonstrates 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.
Dim fso, outFile Set fso = CreateObject("Scripting.FileSystemObject") 'Create a Unicode (utf-16) output text file. Set outFile = fso.CreateTextFile("output.txt", True, True) ' This example requires the Chilkat API to have been previously unlocked. ' See Global Unlock Sample for sample code. emlPath = "C:/AAWorkarea/beatrix/roesner.eml" ' For versions of Chilkat < 10.0.0, use CreateObject("Chilkat_9_5_0.Mime") set mime = CreateObject("Chilkat.Mime") success = mime.LoadMimeFile(emlPath) If (success <> 1) Then outFile.WriteLine(mime.LastErrorText) WScript.Quit End If outFile.WriteLine("---- MIME structure ----") outFile.WriteLine(mime.GetStructure("text")) outFile.WriteLine("------------------------") ' For versions of Chilkat < 10.0.0, use CreateObject("Chilkat_9_5_0.Email") set email = CreateObject("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. outFile.WriteLine("Email was Signed: " & email.ReceivedSigned) outFile.WriteLine("Email was Encrypted: " & email.ReceivedEncrypted) If (email.ReceivedSigned = 1) Then outFile.WriteLine("Signature(s) valid = " & email.SignaturesValid) End If If (email.ReceivedEncrypted = 1) Then outFile.WriteLine("Decrypted successfully = " & email.Decrypted) End If i = 0 numAttach = email.NumAttachments outFile.WriteLine("Number of attachments = " & numAttach) Do While i < numAttach outFile.WriteLine("---- Attachment " & i) ' Examine the filename (if any) outFile.WriteLine("filename: " & email.GetAttachmentFilename(i)) ' Examine the content-ID (if any) outFile.WriteLine("Content-ID: " & email.GetAttachmentContentID(i)) ' Examine the content-type outFile.WriteLine("Content-Type: " & email.GetAttachmentContentType(i)) ' Examine the content-disposition outFile.WriteLine("Content-Disposition" & email.GetAttachmentHeader(i,"content-disposition")) ' Examine the attachment size: outFile.WriteLine("Size (in bytes) of the attachment: " & email.GetAttachmentSize(i)) i = i + 1 Loop outFile.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. numRelated = email.NumRelatedItems outFile.WriteLine("Number of related items = " & numRelated) i = 0 Do While i < numRelated outFile.WriteLine("---- Related Item " & i) ' Examine the filename (if any) outFile.WriteLine("filename: " & email.GetRelatedFilename(i)) ' Examine the content-ID (if any) outFile.WriteLine("Content-ID: " & email.GetRelatedContentID(i)) ' Examine the content-type outFile.WriteLine("Content-Type: " & email.GetRelatedContentType(i)) ' Examine the content-location (if any) outFile.WriteLine("Content-Location" & email.GetRelatedContentLocation(i)) i = i + 1 Loop ' The email could also have attached messages. ' An attached message is another email that was attached to this email. numAttachedMessages = email.NumAttachedMessages outFile.WriteLine("Number of attached messages = " & numAttachedMessages) i = 0 Do While i < numAttachedMessages outFile.WriteLine("---- Attached message " & i) ' Examine the attached email ' em is a Chilkat.Email Set em = email.GetAttachedMessage(i) outFile.WriteLine("from: " & em.From) outFile.WriteLine("subject: " & em.Subject) i = i + 1 Loop ' An email could also be a multipart/report email. ' This is a DSN (Delivery Status Notification) ' The NumReports property indicates how many "reports" exist. numReports = email.NumReports outFile.WriteLine("Number of reports = " & numReports) i = 0 Do While i < numReports outFile.WriteLine("---- Report " & i) ' Get the raw report data... outFile.WriteLine(email.GetReport(i)) i = i + 1 Loop ' 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() = 1) Then outFile.WriteLine("--- Delivery Status Information:") outFile.WriteLine("Status: " & email.GetDeliveryStatusInfo("Status")) outFile.WriteLine("Action: " & email.GetDeliveryStatusInfo("Action")) outFile.WriteLine("Reporting-MTA: " & email.GetDeliveryStatusInfo("Reporting-MTA")) ' sa is a Chilkat.StringArray Set sa = email.GetDsnFinalRecipients() numFinalRecipients = sa.Count i = 0 Do While i < numFinalRecipients outFile.WriteLine("final recipient: " & sa.GetString(i)) i = i + 1 Loop End If outFile.Close |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.