|  | 
Chilkat  HOME  Android™  AutoIt  C  C#  C++  Chilkat2-Python  CkPython  Classic ASP  DataFlex  Delphi DLL  Go  Java  Node.js  Objective-C  PHP Extension  Perl  PowerBuilder  PowerShell  PureBasic  Ruby  SQL Server  Swift  Tcl  Unicode C  Unicode C++  VB.NET  VBScript  Visual Basic 6.0  Visual FoxPro  Xojo Plugin
| (Visual Basic 6.0) Scan for Emails with Attachments and Save Attachments to FilesScan for emails with attachments and save attachments. Note: This example requires Chilkat v11.0.0 or greater. 
 Dim success As Long success = 0 ' This example requires the Chilkat API to have been previously unlocked. ' See Global Unlock Sample for sample code. Dim imap As New ChilkatImap ' Connect to an IMAP server. ' Use TLS imap.Ssl = 1 imap.Port = 993 success = imap.Connect("imap.example.com") If (success = 0) Then Debug.Print imap.LastErrorText Exit Sub End If ' Login success = imap.Login("myLogin","myPassword") If (success = 0) Then Debug.Print imap.LastErrorText Exit Sub End If ' Select an IMAP mailbox success = imap.SelectMailbox("Inbox") If (success = 0) Then Debug.Print imap.LastErrorText Exit Sub End If ' We can choose to fetch UIDs or sequence numbers. Dim fetchUids As Long fetchUids = 1 ' Get the message IDs of all the emails in the mailbox Dim messageSet As New MessageSet success = imap.QueryMbx("ALL",fetchUids,messageSet) If (success = 0) Then Debug.Print imap.LastErrorText Exit Sub End If ' Fetch the email headers into a bundle object: Dim bundle As New ChilkatEmailBundle Dim headersOnly As Long headersOnly = 1 success = imap.FetchMsgSet(headersOnly,messageSet,bundle) If (success = 0) Then Debug.Print imap.LastErrorText Exit Sub End If ' Scan for emails with attachments, and save the attachments ' to a sub-directory. Dim fullEmail As New ChilkatEmail Dim emailHeader As New ChilkatEmail Dim i As Long i = 0 Do While i < bundle.MessageCount ' The bundle contains email headers.. success = bundle.EmailAt(i,emailHeader) ' Does this email have attachments? ' Use GetMailNumAttach because the attachments ' are not actually in the email object because ' we only downloaded headers. Dim numAttach As Long numAttach = imap.GetMailNumAttach(emailHeader) If (numAttach > 0) Then ' Download the entire email and save the ' attachments. (Remember, we ' need to download the entire email because ' only the headers were previously downloaded. ' The ckx-imap-uid header field is added when ' headers are downloaded. This makes it possible ' to get the UID from the email object. Dim uidStr As String uidStr = emailHeader.GetHeaderField("ckx-imap-uid") Dim uid As Long uid = CLng(uidStr) success = imap.FetchEmail(0,uid,1,fullEmail) If (success = 0) Then Debug.Print imap.LastErrorText Exit Sub End If success = fullEmail.SaveAllAttachments("attachmentsDir") Dim j As Long For j = 0 To numAttach - 1 Dim filename As String filename = imap.GetMailAttachFilename(emailHeader,j) Debug.Print filename Next End If i = i + 1 Loop ' Disconnect from the IMAP server. success = imap.Disconnect() | ||||
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.