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
(PureBasic) 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.
IncludeFile "CkImap.pb" IncludeFile "CkEmailBundle.pb" IncludeFile "CkMessageSet.pb" IncludeFile "CkEmail.pb" Procedure ChilkatExample() ; This example assumes the Chilkat API to have been previously unlocked. ; See Global Unlock Sample for sample code. imap.i = CkImap::ckCreate() If imap.i = 0 Debug "Failed to create object." ProcedureReturn EndIf ; Indicate that STARTTLS should be used to convert ; to a secure TLS/SSL connection: CkImap::setCkStartTls(imap, 1) CkImap::setCkPort(imap, 143) ; Connect to an IMAP server and convert the connection ; to TLS/SSL via STARTTLS. success.i = CkImap::ckConnect(imap,"imap.someMailServer.com") If success <> 1 Debug CkImap::ckLastErrorText(imap) CkImap::ckDispose(imap) ProcedureReturn EndIf ; The remainder of this example is the same as for ; non-TLS/SSL... ; Login success = CkImap::ckLogin(imap,"myLogin","myPassword") If success <> 1 Debug CkImap::ckLastErrorText(imap) CkImap::ckDispose(imap) ProcedureReturn EndIf ; Select an IMAP mailbox success = CkImap::ckSelectMailbox(imap,"Inbox") If success <> 1 Debug CkImap::ckLastErrorText(imap) CkImap::ckDispose(imap) ProcedureReturn EndIf messageSet.i ; We can choose to fetch UIDs or sequence numbers. fetchUids.i = 1 ; Get the message IDs of all the emails in the mailbox messageSet = CkImap::ckSearch(imap,"ALL",fetchUids) If CkImap::ckLastMethodSuccess(imap) = 0 Debug CkImap::ckLastErrorText(imap) CkImap::ckDispose(imap) ProcedureReturn EndIf ; Fetch the emails into a bundle object: bundle.i bundle = CkImap::ckFetchBundle(imap,messageSet) If CkImap::ckLastMethodSuccess(imap) = 0 CkMessageSet::ckDispose(messageSet) Debug CkImap::ckLastErrorText(imap) CkImap::ckDispose(imap) ProcedureReturn EndIf ; Loop over the bundle and display the FROM and SUBJECT of each. i.i = 0 numEmails.i = CkEmailBundle::ckMessageCount(bundle) While i < numEmails email.i = CkEmailBundle::ckGetEmail(bundle,i) Debug CkEmail::ckFrom(email) Debug CkEmail::ckSubject(email) Debug "--" CkEmail::ckDispose(email) i = i + 1 Wend ; Disconnect from the IMAP server. success = CkImap::ckDisconnect(imap) CkMessageSet::ckDispose(messageSet) CkEmailBundle::ckDispose(bundle) CkImap::ckDispose(imap) ProcedureReturn EndProcedure |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.