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
(Classic ASP) Bounced Email HandlingDemonstrates how to examine emails and detect which are bounced (automated) replies. Classifies each email according to the type of bounce.
<html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> </head> <body> <% ' This example requires the Chilkat API to have been previously unlocked. ' See Global Unlock Sample for sample code. ' For versions of Chilkat < 10.0.0, use CreateObject("Chilkat_9_5_0.Bounce") set bounce = Server.CreateObject("Chilkat.Bounce") ' The mailman object is used for receiving (POP3) ' and sending (SMTP) email. ' For versions of Chilkat < 10.0.0, use CreateObject("Chilkat_9_5_0.MailMan") set mailman = Server.CreateObject("Chilkat.MailMan") ' Set the POP3 server's hostname mailman.MailHost = "mail.chilkatsoft.com" ' Set the POP3 login/password. mailman.PopUsername = "myLogin" mailman.PopPassword = "myPassword" ' Copy the all email from the user's POP3 mailbox ' into a bundle object. The email remains on the server. ' (There are other methods for deleting email from a POP3 server.) ' bundle is a Chilkat.EmailBundle Set bundle = mailman.CopyMail() If (mailman.LastMethodSuccess = 0) Then Response.Write "<pre>" & Server.HTMLEncode( mailman.LastErrorText) & "</pre>" Response.End End If i = 0 Do While i < bundle.MessageCount ' email is a Chilkat.Email Set email = bundle.GetEmail(i) success = bounce.ExamineEmail(email) If (success = 0) Then Response.Write "<pre>" & Server.HTMLEncode( bounce.LastErrorText) & "</pre>" Response.End End If If (bounce.BounceType = 1) Then ' Hard bounce, log the email address Response.Write "<pre>" & Server.HTMLEncode( "Hard Bounce: " & bounce.BounceAddress) & "</pre>" End If If (bounce.BounceType = 2) Then ' Soft bounce, log the email address Response.Write "<pre>" & Server.HTMLEncode( "Soft Bounce: " & bounce.BounceAddress) & "</pre>" End If If (bounce.BounceType = 3) Then ' General bounce, no email address available. Response.Write "<pre>" & Server.HTMLEncode( "General Bounce: No email address") & "</pre>" End If If (bounce.BounceType = 4) Then ' General bounce, log the email address Response.Write "<pre>" & Server.HTMLEncode( "General Bounce: " & bounce.BounceAddress) & "</pre>" End If If (bounce.BounceType = 5) Then ' Mail blocked, log the email address ' A bounce occured because the sender was blocked. Response.Write "<pre>" & Server.HTMLEncode( "Mail Blocked: " & bounce.BounceAddress) & "</pre>" End If If (bounce.BounceType = 6) Then ' Auto-reply, log the email address Response.Write "<pre>" & Server.HTMLEncode( "Auto-Reply: " & bounce.BounceAddress) & "</pre>" End If If (bounce.BounceType = 7) Then ' Transient (recoverable) Failure, log the email address Response.Write "<pre>" & Server.HTMLEncode( "Transient Failure: " & bounce.BounceAddress) & "</pre>" End If If (bounce.BounceType = 8) Then ' Subscribe request, log the email address Response.Write "<pre>" & Server.HTMLEncode( "Subscribe Request: " & bounce.BounceAddress) & "</pre>" End If If (bounce.BounceType = 9) Then ' Unsubscribe Request, log the email address Response.Write "<pre>" & Server.HTMLEncode( "Unsubscribe Request: " & bounce.BounceAddress) & "</pre>" End If If (bounce.BounceType = 10) Then ' Virus Notification, log the email address Response.Write "<pre>" & Server.HTMLEncode( "Virus Notification: " & bounce.BounceAddress) & "</pre>" End If If (bounce.BounceType = 11) Then ' Suspected bounce. ' This should be rare. It indicates that the Bounce ' component found strong evidence that this is a bounced ' email, but couldn't quite recognize everything it ' needed to be 100% sure. Feel free to notify ' support@chilkatsoft.com regarding emails having this ' bounce type. Response.Write "<pre>" & Server.HTMLEncode( "Suspected Bounce!") & "</pre>" End If If (bounce.BounceType = 12) Then ' Challenge/Response - Auto-reply message sent by SPAM software ' where only verified email addresses are accepted. Response.Write "<pre>" & Server.HTMLEncode( "Challenge: " & bounce.BounceAddress) & "</pre>" End If If (bounce.BounceType = 13) Then ' Address Change Notification Message. Response.Write "<pre>" & Server.HTMLEncode( "Address Change: " & bounce.BounceAddress) & "</pre>" End If If (bounce.BounceType = 14) Then ' Success DSN indicating that the message was successfully relayed. Response.Write "<pre>" & Server.HTMLEncode( "DSN Successful Relay: ") & "</pre>" End If i = i + 1 Loop success = mailman.Pop3EndSession() %> </body> </html> |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.