Chilkat HOME Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi DLL Go Java Node.js Objective-C PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(PHP Extension) Scan for Emails with Attachments and Save Attachments to FilesScan for emails with attachments and save attachments.
<?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; } // Login $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; } // Fetch the email headers into a bundle object: // bundle is a CkEmailBundle $bundle = $imap->FetchHeaders($messageSet); if ($imap->get_LastMethodSuccess() != true) { print $imap->lastErrorText() . "\n"; exit; } // Scan for emails with attachments, and save the attachments // to a sub-directory. for ($i = 0; $i <= $bundle->get_MessageCount() - 1; $i++) { // email is a CkEmail $email = $bundle->GetEmail($i); // Does this email have attachments? // Use GetMailNumAttach because the attachments // are not actually in the email object because // we only downloaded headers. // (Had we downloaded the full emails by // calling mailman.FetchBundle, we could look // at the email object's NumAttachments property.) $numAttach = $imap->GetMailNumAttach($email); if ($numAttach > 0) { // Download the entire email and save the // attachments. (Remember, we // need to download the entire email because // only the headers were previously downloaded. // If the entire emails were downloaded by // calling FetchBundle instead of FetchHeaders, // this would not be necessary. // The ckx-imap-uid header field is added when // headers are downloaded. This makes it possible // to get the UID from the email object. $uidStr = $email->getHeaderField('ckx-imap-uid'); $uid = $uidStr; // fullEmail is a CkEmail $fullEmail = $imap->FetchSingle($uid,true); if ($imap->get_LastMethodSuccess() == true) { $success = $fullEmail->SaveAllAttachments('attachmentsDir'); } for ($j = 0; $j <= $numAttach - 1; $j++) { $filename = $imap->getMailAttachFilename($email,$j); print $filename . "\n"; } } } // Disconnect from the IMAP server. $success = $imap->Disconnect(); ?> |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.