Chilkat HOME ASP Visual Basic VB.NET C# Visual C++ C MFC Delphi FoxPro Java Perl PHP Python Ruby SQL Server VBScript
Reading Unread POP3 Email
The 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. ' The mailman object is used for receiving (POP3) ' and sending (SMTP) email. Dim mailman As New Chilkat.MailMan() ' Any string argument automatically begins the 30-day trial. Dim success As Boolean success = mailman.UnlockComponent("30-day trial") If (success <> true) Then MsgBox("Component unlock failed") Exit Sub End If ' Set the POP3 server's hostname mailman.MailHost = "mail.chilkatsoft.com" ' Set the POP3 login/password. mailman.PopUsername = "***" mailman.PopPassword = "***" ' We're keeping 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 New Chilkat.StringArray() success = saSeenUidls.LoadFromFile("seenUidls.txt") If (success <> true) Then MsgBox("failed to load seenUidls.txt") Exit Sub End If ' Get the complete list of UIDLs on the mail server. Dim saUidls As Chilkat.StringArray saUidls = mailman.GetUidls() If (saUidls Is Nothing ) Then MsgBox(mailman.LastErrorText) Exit Sub End If ' We don't have set operators (yet) on the StringArray object, ' so 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 New Chilkat.StringArray() Dim i As Long Dim n As Long n = saUidls.Count For i = 0 To n - 1 If (saSeenUidls.Contains(saUidls.GetString(i)) <> true) Then saUnseenUidls.Append(saUidls.GetString(i)) End If Next If (saUnseenUidls.Count = 0) Then MsgBox("No unseen emails!") Exit Sub End If ' Download in full the unseen emails: Dim bundle As Chilkat.EmailBundle bundle = mailman.FetchMultiple(saUnseenUidls) If (bundle Is Nothing ) Then MsgBox(mailman.LastErrorText) Exit Sub End If Dim email As Chilkat.Email For i = 0 To bundle.MessageCount - 1 email = bundle.GetEmail(i) TextBox1.Text = TextBox1.Text & email.From & vbCrLf TextBox1.Refresh() TextBox1.Text = TextBox1.Text & email.Subject & vbCrLf TextBox1.Refresh() TextBox1.Text = TextBox1.Text & "----" & vbCrLf TextBox1.Refresh() Next ' We've seen all the emails, save saUidls to "seenUidls.txt" saUidls.SaveToFile("seenUidls.txt") |
Need a specific example? Send a request to support@chilkatsoft.com
© 2000-2010 Chilkat Software, Inc. All Rights Reserved.