Chilkat HOME Android™ Classic ASP C C++ C# Mono C# .NET Core C# C# UWP/WinRT DataFlex Delphi ActiveX Delphi DLL Visual FoxPro Java Lianja MFC Objective-C Perl PHP ActiveX PHP Extension PowerBuilder PowerShell PureBasic CkPython Chilkat2-Python Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ Visual Basic 6.0 VB.NET VB.NET UWP/WinRT VBScript Xojo Plugin Node.js Excel Go
(Excel) Reading Unread POP3 EmailThe POP3 protocol does not provide the ability to ask the server which emails are "unread". Furthermore, a pure POP3 server does not even keep this information. Some servers, such as Exchange Server, expose both POP3 and IMAP interfaces. In these cases, information about read/unread status exists on the server, but it is only available via the IMAP protocol. Email clients such as Outlook and Thunderbird keep read/unread information on the client computer. This example demonstrates how UIDLs can be saved to track and read "unread" email.
' This example requires the Chilkat API to have been previously unlocked. ' See Global Unlock Sample for sample code. ' The mailman object is used for receiving (POP3) ' and sending (SMTP) email. Dim mailman As Chilkat.MailMan Set mailman = Chilkat.NewMailMan ' Set the POP3 server's hostname mailman.MailHost = "pop.someMailServer.com" ' Set the POP3 login/password. mailman.PopUsername = "***" mailman.PopPassword = "***" ' You may keep a list of already-seen UIDLs in a text file: ' If this is the first time you're running this example, ' create an empty text file named "seenUidls.txt" Dim saSeenUidls As Chilkat.StringArray Set saSeenUidls = Chilkat.NewStringArray success = saSeenUidls.LoadFromFile("seenUidls.txt") If (success <> True) Then Debug.Print "failed to load seenUidls.txt" Exit Sub End If ' Get the complete list of UIDLs on the mail server. Set saUidls = mailman.GetUidls() If (mailman.LastMethodSuccess = False) Then Debug.Print mailman.LastErrorText Exit Sub End If ' Create a new string array object (it's an object, not an actual array) ' and add the UIDLs from saUidls that aren't already seen. Dim saUnseenUidls As Chilkat.StringArray Set saUnseenUidls = Chilkat.NewStringArray i = 0 n = saUidls.Count Do While i < n If (saSeenUidls.Contains(saUidls.GetString(i)) <> True) Then success = saUnseenUidls.Append(saUidls.GetString(i)) End If i = i + 1 Loop If (saUnseenUidls.Count = 0) Then Debug.Print "No unseen emails!" Exit Sub End If ' Download in full the unseen emails: Set bundle = mailman.FetchMultiple(saUnseenUidls) If (mailman.LastMethodSuccess = False) Then Debug.Print mailman.LastErrorText Exit Sub End If i = 0 Do While i < bundle.MessageCount Set email = bundle.GetEmail(i) Debug.Print email.From Debug.Print email.Subject Debug.Print "----" i = i + 1 Loop ' Save saUidls to "seenUidls.txt" success = saUidls.SaveToFile("seenUidls.txt") |
© 2000-2022 Chilkat Software, Inc. All Rights Reserved.