PHP ActiveX
PHP ActiveX
POP3 Verify Signed (S/MIME) Email
Demonstrates how to download and verify digitally signed S/MIME email.Chilkat PHP ActiveX Downloads
<?php
$success = 0;
// This example requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
$mailman = new COM("Chilkat.MailMan");
// Set the POP3 server's hostname
$mailman->MailHost = 'pop.example.com';
// Set the POP3 login/password.
$mailman->PopUsername = 'myLogin';
$mailman->PopPassword = 'myPassword';
$stUidls = new COM("Chilkat.StringTable");
$success = $mailman->FetchUidls($stUidls);
if ($success == 0) {
print $mailman->LastErrorText . "\n";
exit;
}
$email = new COM("Chilkat.Email");
$cert = new COM("Chilkat.Cert");
$count = $stUidls->Count;
$i = 0;
while ($i < $count) {
// Download the full email.
$success = $mailman->FetchByUidl($stUidls->stringAt($i),0,0,$email);
if ($success == 0) {
print $mailman->LastErrorText . "\n";
exit;
}
print $i . "\n";
print 'From: ' . $email->From . "\n";
print 'Subject: ' . $email->Subject . "\n";
// 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";
$success = $email->LastSignerCert(0,$cert);
if ($success == 0) {
print $email->LastErrorText . "\n";
exit;
}
print 'Signing cert: ' . $cert->SubjectCN . "\n";
}
}
else {
print 'Digital signature verification failed.' . "\n";
}
$i = $i + 1;
}
$mailman->Pop3EndSession();
?>