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
(Visual FoxPro) 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.
LOCAL loImap LOCAL loCertStore LOCAL lnSuccess LOCAL loCert LOCAL loCert2 LOCAL loMessageSet LOCAL lnFetchUids LOCAL loBundle LOCAL i LOCAL lnNumEmails LOCAL loEmail * This example assumes the Chilkat API to have been previously unlocked. * See Global Unlock Sample for sample code. loImap = CreateObject('Chilkat_9_5_0.Imap') * To use a secure SSL connection, set SSL and the port: loImap.Ssl = 1 * The typical port for IMAP SSL is 993 loImap.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.) loCertStore = CreateObject('Chilkat_9_5_0.CertStore') * The 1st argument is the filename, the 2nd arg is the * PFX file's password: lnSuccess = loCertStore.LoadPfxFile("myCertWithPrivateKey.pfx","secret") IF (lnSuccess <> 1) THEN ? loCertStore.LastErrorText RELEASE loImap RELEASE loCertStore CANCEL ENDIF * Find the certificate by the subject common name: loCert = loCertStore.FindCertBySubjectCN("Chilkat Software, Inc.") IF (loCertStore.LastMethodSuccess = 0) THEN ? loCertStore.LastErrorText RELEASE loImap RELEASE loCertStore CANCEL 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: loCert2 = CreateObject('Chilkat_9_5_0.Cert') * The 1st argument is the filename, the 2nd arg is the * PFX file's password: lnSuccess = loCert2.LoadPfxFile("myClientCert.pfx","secret") IF (lnSuccess <> 1) THEN ? loCert.LastErrorText RELEASE loImap RELEASE loCertStore RELEASE loCert2 CANCEL ENDIF * Use the cert: lnSuccess = loImap.SetSslClientCert(loCert) * Connect to an IMAP server. lnSuccess = loImap.Connect("imap.someMailServer.com") IF (lnSuccess <> 1) THEN ? loImap.LastErrorText RELEASE loImap RELEASE loCertStore RELEASE loCert2 CANCEL ENDIF * Login lnSuccess = loImap.Login("myLogin","myPassword") IF (lnSuccess <> 1) THEN ? loImap.LastErrorText RELEASE loImap RELEASE loCertStore RELEASE loCert2 CANCEL ENDIF * Select an IMAP mailbox lnSuccess = loImap.SelectMailbox("Inbox") IF (lnSuccess <> 1) THEN ? loImap.LastErrorText RELEASE loImap RELEASE loCertStore RELEASE loCert2 CANCEL ENDIF * We can choose to fetch UIDs or sequence numbers. lnFetchUids = 1 * Get the message IDs of all the emails in the mailbox loMessageSet = loImap.Search("ALL",lnFetchUids) IF (loImap.LastMethodSuccess = 0) THEN ? loImap.LastErrorText RELEASE loImap RELEASE loCertStore RELEASE loCert2 CANCEL ENDIF * Fetch the emails into a bundle object: loBundle = loImap.FetchBundle(loMessageSet) IF (loImap.LastMethodSuccess = 0) THEN RELEASE loMessageSet ? loImap.LastErrorText RELEASE loImap RELEASE loCertStore RELEASE loCert2 CANCEL ENDIF * Loop over the bundle and display the FROM and SUBJECT of each. i = 0 lnNumEmails = loBundle.MessageCount DO WHILE i < lnNumEmails loEmail = loBundle.GetEmail(i) ? loEmail.From ? loEmail.Subject ? "--" RELEASE loEmail i = i + 1 ENDDO * Disconnect from the IMAP server. lnSuccess = loImap.Disconnect() RELEASE loMessageSet RELEASE loBundle RELEASE loImap RELEASE loCertStore RELEASE loCert2 |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.