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
(CkPython) IMAP Download and Verify Signed (S/MIME) EmailDemonstrates how to download and verify digitally signed S/MIME email.
import sys import chilkat # This example requires the Chilkat API to have been previously unlocked. # See Global Unlock Sample for sample code. imap = chilkat.CkImap() # Connect to an IMAP server. # Use TLS imap.put_Ssl(True) imap.put_Port(993) success = imap.Connect("imap.someMailServer.com") if (success != True): print(imap.lastErrorText()) sys.exit() success = imap.Login("myLogin","myPassword") if (success != True): print(imap.lastErrorText()) sys.exit() # Select an IMAP mailbox success = imap.SelectMailbox("Inbox") if (success != True): print(imap.lastErrorText()) sys.exit() # We can choose to fetch UIDs or sequence numbers. fetchUids = True # Get the message IDs of all the emails in the mailbox # messageSet is a CkMessageSet messageSet = imap.Search("ALL",fetchUids) if (imap.get_LastMethodSuccess() != True): print(imap.lastErrorText()) sys.exit() # Scan for emails with attachments, and save the attachments # to a sub-directory. i = 0 while i < messageSet.get_Count() : uid = messageSet.GetId(i) print("uid: " + uid) # email is a CkEmail email = imap.FetchSingle(uid,True) # The security layers of signed and/or encrypted emails # are automatically "unwrapped" when loaded into # a Chilkat email object. # An application only needs to check to see if an email # was received signed or encrypted, and then examine # the success/failure. For example: if (email.get_ReceivedSigned() == True): print("This email was signed.") # Check to see if the signatures were verified. if (email.get_SignaturesValid() == True): print("Digital signature(s) verified.") print("Signer: " + email.signedBy()) # The certificate used for signing may be obtained # by calling email.GetSignedByCert. # cert is a CkCert cert = email.GetSignedByCert() if (email.get_LastMethodSuccess() != True): print("Failed to get signing certificate object.") else: print("Signing cert: " + cert.subjectCN()) else: print("Digital signature verification failed.") i = i + 1 # Disconnect from the IMAP server. success = imap.Disconnect() |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.