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
(C) IMAP STARTTLS (Explicit TLS/SSL)The StartTls property is set to force the Connect method to automatically convert an connection to TLS/SSL via the STARTTLS IMAP command. This is also known as "explicit TLS/SSL" as opposed to "implicit TLS/SSL". With implicit TLS/SSL, the IMAP client connects on the well-known IMAP TLS/SSL port 993 and the secure channel is immediately established. With explicit TLS/SSL, the IMAP client connects on the typical non-secure port (143 usually) and the converts the connection via the STARTTLS command.
#include <C_CkImap.h> #include <C_CkMessageSet.h> #include <C_CkEmailBundle.h> #include <C_CkEmail.h> void ChilkatSample(void) { HCkImap imap; BOOL success; HCkMessageSet messageSet; BOOL fetchUids; HCkEmailBundle bundle; int i; int numEmails; HCkEmail email; // This example assumes the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. imap = CkImap_Create(); // Indicate that STARTTLS should be used to convert // to a secure TLS/SSL connection: CkImap_putStartTls(imap,TRUE); CkImap_putPort(imap,143); // Connect to an IMAP server and convert the connection // to TLS/SSL via STARTTLS. success = CkImap_Connect(imap,"imap.someMailServer.com"); if (success != TRUE) { printf("%s\n",CkImap_lastErrorText(imap)); CkImap_Dispose(imap); return; } // The remainder of this example is the same as for // non-TLS/SSL... // Login success = CkImap_Login(imap,"myLogin","myPassword"); if (success != TRUE) { printf("%s\n",CkImap_lastErrorText(imap)); CkImap_Dispose(imap); return; } // Select an IMAP mailbox success = CkImap_SelectMailbox(imap,"Inbox"); if (success != TRUE) { printf("%s\n",CkImap_lastErrorText(imap)); CkImap_Dispose(imap); return; } // We can choose to fetch UIDs or sequence numbers. fetchUids = TRUE; // Get the message IDs of all the emails in the mailbox messageSet = CkImap_Search(imap,"ALL",fetchUids); if (CkImap_getLastMethodSuccess(imap) == FALSE) { printf("%s\n",CkImap_lastErrorText(imap)); CkImap_Dispose(imap); return; } // Fetch the emails into a bundle object: bundle = CkImap_FetchBundle(imap,messageSet); if (CkImap_getLastMethodSuccess(imap) == FALSE) { CkMessageSet_Dispose(messageSet); printf("%s\n",CkImap_lastErrorText(imap)); CkImap_Dispose(imap); return; } // Loop over the bundle and display the FROM and SUBJECT of each. i = 0; numEmails = CkEmailBundle_getMessageCount(bundle); while (i < numEmails) { email = CkEmailBundle_GetEmail(bundle,i); printf("%s\n",CkEmail_ck_from(email)); printf("%s\n",CkEmail_subject(email)); printf("--\n"); CkEmail_Dispose(email); i = i + 1; } // Disconnect from the IMAP server. success = CkImap_Disconnect(imap); CkMessageSet_Dispose(messageSet); CkEmailBundle_Dispose(bundle); CkImap_Dispose(imap); } |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.