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
(SQL Server) Read iCloud Email Account using IMAPDemonstrates how to set the IMAP settings for an iCloud email account and downloads the email from Inbox.
-- Important: See this note about string length limitations for strings returned by sp_OAMethod calls. -- CREATE PROCEDURE ChilkatSample AS BEGIN DECLARE @hr int DECLARE @iTmp0 int -- Important: Do not use nvarchar(max). See the warning about using nvarchar(max). DECLARE @sTmp0 nvarchar(4000) -- This example assumes Chilkat Imap to have been previously unlocked. -- See Unlock Imap for sample code. DECLARE @imap int -- Use "Chilkat_9_5_0.Imap" for versions of Chilkat < 10.0.0 EXEC @hr = sp_OACreate 'Chilkat.Imap', @imap OUT IF @hr <> 0 BEGIN PRINT 'Failed to create ActiveX component' RETURN END -- Connect to the iCloud IMAP Mail Server EXEC sp_OASetProperty @imap, 'Ssl', 1 EXEC sp_OASetProperty @imap, 'Port', 993 DECLARE @success int EXEC sp_OAMethod @imap, 'Connect', @success OUT, 'imap.mail.me.com' IF @success <> 1 BEGIN EXEC sp_OAGetProperty @imap, 'LastErrorText', @sTmp0 OUT PRINT @sTmp0 EXEC @hr = sp_OADestroy @imap RETURN END -- The username is usually the name part of your iCloud email address -- (for example, emilyparker, not emilyparker@icloud.com). EXEC sp_OAMethod @imap, 'Login', @success OUT, 'ICLOUD_USERNAME', 'ICLOUD_PASSWORD' IF @success <> 1 BEGIN EXEC sp_OAGetProperty @imap, 'LastErrorText', @sTmp0 OUT PRINT @sTmp0 EXEC @hr = sp_OADestroy @imap RETURN END -- Select an IMAP folder/mailbox EXEC sp_OAMethod @imap, 'SelectMailbox', @success OUT, 'Inbox' IF @success <> 1 BEGIN EXEC sp_OAGetProperty @imap, 'LastErrorText', @sTmp0 OUT PRINT @sTmp0 EXEC @hr = sp_OADestroy @imap RETURN END -- Once the folder/mailbox is selected, the NumMessages property -- will contain the number of emails in the mailbox. -- Loop from 1 to NumMessages to fetch each email by sequence number. DECLARE @email int DECLARE @i int DECLARE @n int EXEC sp_OAGetProperty @imap, 'NumMessages', @n OUT DECLARE @bUid int SELECT @bUid = 0 SELECT @i = 1 WHILE @i <= @n BEGIN -- Download the email by sequence number. EXEC sp_OAMethod @imap, 'FetchSingle', @email OUT, @i, @bUid EXEC sp_OAGetProperty @imap, 'LastMethodSuccess', @iTmp0 OUT IF @iTmp0 <> 1 BEGIN EXEC sp_OAGetProperty @imap, 'LastErrorText', @sTmp0 OUT PRINT @sTmp0 EXEC @hr = sp_OADestroy @imap RETURN END EXEC sp_OAGetProperty @email, 'From', @sTmp0 OUT PRINT @i + ': ' + @sTmp0 EXEC sp_OAGetProperty @email, 'Subject', @sTmp0 OUT PRINT ' ' + @sTmp0 PRINT '-' EXEC @hr = sp_OADestroy @email SELECT @i = @i + 1 END -- Disconnect from the IMAP server. EXEC sp_OAMethod @imap, 'Disconnect', @success OUT PRINT 'Success.' -- Sample output: -- 1: iCloud <noreply@email.apple.com> -- Welcome to iCloud Mail. -- - -- 2: "Chilkat Software" <support@chilkatsoft.com> -- This is a test -- - -- Success. EXEC @hr = sp_OADestroy @imap END GO |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.