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 ActiveX) Download and Save Email Attachments (POP3)See more POP3 ExamplesDownloads emails from a POP3 mailbox and saves all attachments.
<?php // This example assumes the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. // The mailman object is used for receiving (POP3) // and sending (SMTP) email. // For versions of Chilkat < 10.0.0, use new COM('Chilkat_9_5_0.Chilkat.MailMan') $mailman = new COM("Chilkat.MailMan"); // Set the POP3 server's hostname $mailman->MailHost = 'pop.yourserver.com'; // Set the POP3 login/password. $mailman->PopUsername = '***'; $mailman->PopPassword = '***'; // Copy the all email from the user's POP3 mailbox // into a bundle object. The email remains on the server. // CopyMail is a reasonable choice for POP3 maildrops that don't have too many // emails. For larger mail drops, one might download emails one at a time.. // bundle is a Chilkat.EmailBundle $bundle = $mailman->CopyMail(); if ($mailman->LastMethodSuccess != 1) { print $mailman->LastErrorText . "\n"; exit; } // The directory path can be relative or absolute. // This shows a Windows style directory path. On other operating systems, the path // would be different.. $dirPath = 'c:/myAttachments'; $bundleIndex = 0; $numMessages = $bundle->MessageCount; while (($bundleIndex < $numMessages)) { // email is a Chilkat.Email $email = $bundle->GetEmail($bundleIndex); // Save all attachments to the specified directory. // The directory is automatically created if it does not yet exist. $success = $email->SaveAllAttachments($dirPath); if ($success != 1) { print $email->LastErrorText . "\n"; exit; } // The OverwriteExisting property controls whether already-existing files // are automatically overwritten. By default, it is set to 1 so that existing // files will be overwritten. // Setting OverwriteExisting = 0 will cause the attachment-saving methods to generate // unique filenames if a file with the same name already exists. The actual filename(s) // saved will be present by calling GetAttachmentFilename for each attachment *after* // saving. // For example... $email->OverwriteExisting = 0; $success = $email->SaveAllAttachments($dirPath); if ($success != 1) { print $email->LastErrorText . "\n"; exit; } $numAttachments = $email->NumAttachments; $attachIndex = 0; while (($attachIndex < $numAttachments)) { // If the attachment filename was changed to prevent overwriting, // GetAttachmentFilename will return the new filename. print $email->getAttachmentFilename($attachIndex) . "\n"; $attachIndex = $attachIndex + 1; } // Attachments can also be saved individually. $attachIndex = 0; while (($attachIndex < $numAttachments)) { print 'Original Filename: ' . $email->getAttachmentFilename($attachIndex) . "\n"; $success = $email->SaveAttachedFile($attachIndex,$dirPath); if ($success != 1) { print $email->LastErrorText . "\n"; exit; } // If OverwriteExisting = 1, the saved filename will always equal the original filename, // unless there are characters present in the filename that are not allowed by Windows, // such as * ? < > | etc. In those cases the illegal characters are either removed or replaced // with underscore characters to allow the file to be saved. print 'Saved Filename: ' . $email->getAttachmentFilename($attachIndex) . "\n"; $attachIndex = $attachIndex + 1; } $bundleIndex = $bundleIndex + 1; } ?> |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.