Sample code for 30+ languages & platforms
PHP ActiveX

IMAP Download and Verify Signed (S/MIME) Email

See more IMAP Examples

Demonstrates how to download and verify digitally signed S/MIME email.

Chilkat PHP ActiveX Downloads

PHP ActiveX
<?php

$success = 0;

// This example requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.

$imap = new COM("Chilkat.Imap");

// Connect to an IMAP server.
// Use TLS
$imap->Ssl = 1;
$imap->Port = 993;
$success = $imap->Connect('imap.example.com');
if ($success == 0) {
    print $imap->LastErrorText . "\n";
    exit;
}

$success = $imap->Login('myLogin','myPassword');
if ($success == 0) {
    print $imap->LastErrorText . "\n";
    exit;
}

// Select an IMAP mailbox
$success = $imap->SelectMailbox('Inbox');
if ($success == 0) {
    print $imap->LastErrorText . "\n";
    exit;
}

// We can choose to fetch UIDs or sequence numbers.
$fetchUids = 1;

// Get the message IDs of all the emails in the mailbox
$messageSet = new COM("Chilkat.MessageSet");
$success = $imap->QueryMbx('ALL',$fetchUids,$messageSet);
if ($success == 0) {
    print $imap->LastErrorText . "\n";
    exit;
}

$email = new COM("Chilkat.Email");
$cert = new COM("Chilkat.Cert");

$i = 0;
while ($i < $messageSet->Count) {

    $uid = $messageSet->GetId($i);
    print 'uid: ' . $uid . "\n";

    $success = $imap->FetchEmail(0,$uid,1,$email);
    if ($success == 0) {
        print $imap->LastErrorText . "\n";
        exit;
    }

    // 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->ReceivedSigned == 1) {

        print 'This email was signed.' . "\n";

        // Check to see if the signatures were verified.
        if ($email->SignaturesValid == 1) {
            print 'Digital signature(s) verified.' . "\n";
            print 'Signer: ' . $email->SignedBy . "\n";

            // Get the certificate used for signing.
            $success = $email->LastSignerCert(0,$cert);

            if ($success == 0) {
                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();

?>