Chilkat HOME Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi DLL Go Java Node.js Objective-C PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(AutoIt) Using Client Certificate w/ IMAP SSLDemonstrates how to use a client-side certificate with an IMAP SSL connection. The SetSslClientCert method is called to specify a certificate to be used for the SSL connection.
; This example assumes the Chilkat API to have been previously unlocked. ; See Global Unlock Sample for sample code. $oImap = ObjCreate("Chilkat.Imap") ; To use a secure SSL connection, set SSL and the port: $oImap.Ssl = True ; The typical port for IMAP SSL is 993 $oImap.Port = 993 ; Load a certificate from a PFX file and use it. ; Note: Other methods are available to load pre-installed ; certificates from registry-based certificate stores. ; Create an instance of a certificate store object, load a PFX file, ; locate the certificate we need, and use it for signing. ; (a PFX file may contain more than one certificate.) $oCertStore = ObjCreate("Chilkat.CertStore") ; The 1st argument is the filename, the 2nd arg is the ; PFX file's password: Local $bSuccess = $oCertStore.LoadPfxFile("myCertWithPrivateKey.pfx","secret") If ($bSuccess <> True) Then ConsoleWrite($oCertStore.LastErrorText & @CRLF) Exit EndIf ; Find the certificate by the subject common name: Local $oCert $oCert = $oCertStore.FindCertBySubjectCN("Chilkat Software, Inc.") If ($oCertStore.LastMethodSuccess = False) Then ConsoleWrite($oCertStore.LastErrorText & @CRLF) Exit EndIf ; If a PFX file is known to contain a single certificate, ; you may load it directly into a Chilkat certificate object. ; This snippet of source code shows how: $oCert2 = ObjCreate("Chilkat.Cert") ; The 1st argument is the filename, the 2nd arg is the ; PFX file's password: $bSuccess = $oCert2.LoadPfxFile("myClientCert.pfx","secret") If ($bSuccess <> True) Then ConsoleWrite($oCert.LastErrorText & @CRLF) Exit EndIf ; Use the cert: $bSuccess = $oImap.SetSslClientCert($oCert) ; Connect to an IMAP server. $bSuccess = $oImap.Connect("imap.someMailServer.com") If ($bSuccess <> True) Then ConsoleWrite($oImap.LastErrorText & @CRLF) Exit EndIf ; Login $bSuccess = $oImap.Login("myLogin","myPassword") If ($bSuccess <> True) Then ConsoleWrite($oImap.LastErrorText & @CRLF) Exit EndIf ; Select an IMAP mailbox $bSuccess = $oImap.SelectMailbox("Inbox") If ($bSuccess <> True) Then ConsoleWrite($oImap.LastErrorText & @CRLF) Exit EndIf Local $oMessageSet ; We can choose to fetch UIDs or sequence numbers. Local $bFetchUids = True ; Get the message IDs of all the emails in the mailbox $oMessageSet = $oImap.Search("ALL",$bFetchUids) If ($oImap.LastMethodSuccess = False) Then ConsoleWrite($oImap.LastErrorText & @CRLF) Exit EndIf ; Fetch the emails into a bundle object: Local $oBundle $oBundle = $oImap.FetchBundle($oMessageSet) If ($oImap.LastMethodSuccess = False) Then ConsoleWrite($oImap.LastErrorText & @CRLF) Exit EndIf ; Loop over the bundle and display the FROM and SUBJECT of each. Local $i = 0 Local $iNumEmails = $oBundle.MessageCount While $i < $iNumEmails Local $oEmail = $oBundle.GetEmail($i) ConsoleWrite($oEmail.From & @CRLF) ConsoleWrite($oEmail.Subject & @CRLF) ConsoleWrite("--" & @CRLF) $i = $i + 1 Wend ; Disconnect from the IMAP server. $bSuccess = $oImap.Disconnect() |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.