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
(PHP Extension) IMAP Download and Verify Signed (S/MIME) EmailDemonstrates how to download and verify digitally signed S/MIME email.
<?php // The version number (9_5_0) should match version of the Chilkat extension used, omitting the micro-version number. // For example, if using Chilkat v9.5.0.48, then include as shown here: include("chilkat_9_5_0.php"); // This example requires the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. $imap = new 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() . "\n"; exit; } $success = $imap->Login('myLogin','myPassword'); if ($success != true) { print $imap->lastErrorText() . "\n"; exit; } // Select an IMAP mailbox $success = $imap->SelectMailbox('Inbox'); if ($success != true) { print $imap->lastErrorText() . "\n"; 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() . "\n"; 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 . "\n"; // 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.' . "\n"; // Check to see if the signatures were verified. if ($email->get_SignaturesValid() == true) { print 'Digital signature(s) verified.' . "\n"; print 'Signer: ' . $email->signedBy() . "\n"; // 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.' . "\n"; } else { print 'Signing cert: ' . $cert->subjectCN() . "\n"; } } else { print 'Digital signature verification failed.' . "\n"; } } $i = $i + 1; } // Disconnect from the IMAP server. $success = $imap->Disconnect(); ?> |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.