面向对象的PHP IMAP

0.5.3 2016-04-24 17:47 UTC

This package is not auto-updated.

Last update: 2024-09-14 18:53:06 UTC


README

Build Status Scrutinizer Code Quality Code Coverage Latest Stable Version

一个用于通过IMAP读取和处理的PHP 5.4+库。

安装

确保已安装PHP IMAP扩展。例如在Debian上

# apt-get install php5-imap

推荐通过Composer安装IMAP库

$ composer require ddeboer/imap

此命令要求您全局安装Composer,如Composer文档中的安装章节中所述。

使用方法

连接和验证

use Ddeboer\Imap\Server;

$server = new Server('imap.gmail.com');

// $connection is instance of \Ddeboer\Imap\Connection
$connection = $server->authenticate('my_username', 'my_password');

选项

您可以指定到服务器的端口、标志和参数

$server = new Server(
    $hostname, // required
    $port,     // defaults to 993
    $flags,    // defaults to '/imap/ssl/validate-cert'
    $parameters
);

邮箱

从邮件服务器检索邮箱(也称为邮件文件夹)并遍历它们

$mailboxes = $connection->getMailboxes();

foreach ($mailboxes as $mailbox) {
    // $mailbox is instance of \Ddeboer\Imap\Mailbox
    printf('Mailbox %s has %s messages', $mailbox->getName(), $mailbox->count());
}

或检索特定邮箱

$mailbox = $connection->getMailbox('INBOX');

删除邮箱

$mailbox->delete();

邮件

从邮箱检索邮件(电子邮件)并遍历它们

$messages = $mailbox->getMessages();

foreach ($messages as $message) {
    // $message is instance of \Ddeboer\Imap\Message
}

搜索邮件

use Ddeboer\Imap\SearchExpression;
use Ddeboer\Imap\Search\Email\To;
use Ddeboer\Imap\Search\Text\Body;

$search = new SearchExpression();
$search->addCondition(new To('me@here.com'))
    ->addCondition(new Body('contents'))
;

$messages = $mailbox->getMessages($search);

邮件属性和操作

获取邮件编号和唯一的邮件ID,形式为<...>

$message->getNumber();
$message->getId();

获取其他邮件属性

$message->getSubject();
$message->getFrom();
$message->getTo();
$message->getDate();
$message->isAnswered();
$message->isDeleted();
$message->isDraft();
$message->isSeen();

获取邮件头作为\Ddeboer\Imap\Message\Headers对象

$message->getHeaders();

获取邮件体作为HTML或纯文本

$message->getBodyHtml();
$message->getBodyText();

读取邮件体将邮件标记为已读。如果您想保持邮件未读

$message->keepUnseen()->getBodyHtml();

将邮件移动到另一个邮箱

$mailbox = $connection->getMailbox('another-mailbox');
$message->move($mailbox);

删除邮件

$mailbox->getMessage(1)->delete();
$mailbox->getMessage(2)->delete();
$mailbox->expunge();

邮件附件

获取邮件附件(包括内联和附加的)并遍历它们

$attachments = $message->getAttachments();

foreach ($attachments as $attachment) {
    // $attachment is instance of \Ddeboer\Imap\Message\Attachment
}

将邮件附件下载到本地文件

// getDecodedContent() decodes the attachment’s contents automatically:
file_put_contents(
    '/my/local/dir/' . $attachment->getFilename(),
    $attachment->getDecodedContent()
);

运行测试

此库在Travis CI上对Gmail IMAP服务器进行了功能测试。

如果您有自己的IMAP(测试)账户,您可以通过提供您的IMAP(例如,Gmail)凭据在本地运行测试

$ composer install --dev
$ EMAIL_USERNAME="your_username" EMAIL_PASSWORD="your_password" vendor/bin/phpunit

您还可以设置一个EMAIL_SERVER变量,默认为imap.gmail.com

$ EMAIL_USERNAME="your_username" EMAIL_PASSWORD="your_password" EMAIL_SERVER="imap.you.com" vendor/bin/phpunit