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
(Visual Basic 6.0) Iterate MIME Parts of an EmailDemonstrates how to iterate over the MIME sub-parts of an email, and retrieve the content of each MIME sub-part body. Note: This example requires some new features added to Chilkat v9.5.0.95.
' This example assumes the Chilkat API to have been previously unlocked. ' See Global Unlock Sample for sample code. ' See the following Chilkat post to Quickly Understand Email MIME Dim email As New ChilkatEmail Dim success As Long success = email.LoadEml("qa_data/eml/sample.eml") If (success = 0) Then Debug.Print "Failed to load .eml" Exit Sub End If Dim sbContentType As New ChilkatStringBuilder Dim caseSensitive As Long caseSensitive = 0 ' Get the total number of non-multipart MIME sub-parts. ' (This is a simple way of iterating over all the MIME leaf parts regardless of the MIME tree structure) Dim inlineOnly As Long inlineOnly = 0 Dim excludeAttachments As Long excludeAttachments = 0 Dim searchSpec As String searchSpec = "*/*" Dim numParts As Long numParts = email.GetNumPartsOfType(searchSpec,inlineOnly,excludeAttachments) Dim i As Long i = 0 Do While i < numParts ' What is the Content-Type of this MIME part? success = sbContentType.Append(email.GetNthContentType(i,searchSpec,inlineOnly,excludeAttachments)) If (sbContentType.StartsWith("text/",caseSensitive) = 1) Then ' Get the text body of this MIME part. Dim textBody As String textBody = email.GetNthTextPartOfType(i,searchSpec,inlineOnly,excludeAttachments) Debug.Print "Got text body for " & sbContentType.GetAsString() Else If (sbContentType.ContentsEqual("message/rfc822",caseSensitive) = 1) Then ' If the Content-Type is message/rfc822, then the MIME body for this part contains a full embedded MIME messages. ' Your application could load it into a Chilkat email object and recursively process... Dim attachedEmail As New ChilkatEmail Dim bdMime As New ChilkatBinData success = email.GetNthBinaryPartOfTypeBd(i,searchSpec,inlineOnly,excludeAttachments,bdMime) success = attachedEmail.SetFromMimeBd(bdMime) ' Now your app can recursively process the attachedEmail... Else ' Get the bytes of this MIME body part. Dim bd As New ChilkatBinData success = email.GetNthBinaryPartOfTypeBd(i,searchSpec,inlineOnly,excludeAttachments,bd) Debug.Print "Got binary body for " & sbContentType.GetAsString() & " numBytes = " & bd.NumBytes End If End If sbContentType.Clear i = i + 1 Loop |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.