webklex / php-imap
PHP IMAP 客户端
Requires
- php: ^8.0.2
- ext-fileinfo: *
- ext-iconv: *
- ext-json: *
- ext-libxml: *
- ext-mbstring: *
- ext-openssl: *
- ext-zip: *
- illuminate/pagination: >=5.0.0
- nesbot/carbon: ^2.62.1
- symfony/http-foundation: >=2.8.0
Requires (Dev)
- phpunit/phpunit: ^9.5.10
Suggests
- symfony/mime: Recomended for better extension support
- symfony/var-dumper: Usefull tool for debugging
- 5.5.0
- 5.4.0
- 5.3.0
- 5.2.0
- 5.1.0
- 5.0.1
- 5.0.0
- 4.1.2
- 4.1.1
- 4.1.0
- 4.0.2
- 4.0.1
- 4.0.0
- 3.2.0
- 3.1.0-alpha
- 3.0.0-alpha
- 2.7.2
- 2.7.1
- 2.7.0
- 2.6.0
- 2.5.1
- 2.5.0
- 2.4.4
- 2.4.3
- 2.4.2
- 2.4.1
- 2.4.0
- 2.3.1
- 2.3.0
- 2.2.5
- 2.2.4
- 2.2.3
- 2.2.2
- 2.2.1
- 2.2.0
- 2.1.13
- 2.1.12
- 2.1.11
- 2.1.10
- 2.1.9
- 2.1.8
- 2.1.7
- 2.1.6
- 2.1.5
- 2.1.4
- 2.1.3
- 2.1.2
- 2.1.1
- 2.1.0
- 2.0.1
- 2.0.0
- 1.4.5
- 1.4.2.1
- 1.4.2
- dev-master / 1.0.x-dev
- 0.0.3
- 0.0.2
- 0.0.1
This package is auto-updated.
Last update: 2024-09-11 07:42:10 UTC
README
描述
PHP-IMAP 是一个用于常见 IMAP 通信的包装器,无需安装/启用 php-imap 模块。该协议完全集成,因此支持 IMAP IDLE 操作和“新”OAuth 身份验证过程。您可以启用 php-imap
模块来处理边缘情况、提高消息解码质量,并且如果您想使用像 pop3 这样的旧协议,则必须启用。
官方文档:php-imap.com
Laravel 包装器:webklex/laravel-imap
Discord:discord.gg/rd4cN9h6
目录
文档
- 旧版(< v2.0.0):旧版文档
- 核心文档:php-imap.com
兼容性
基本用法示例
这是一个基本示例,它将在所有 imap 文件夹中输出所有邮件,并将每条消息移动到 INBOX.read。请注意,这不应该在实际生活中进行测试,只是为了给人一个印象。
use Webklex\PHPIMAP\ClientManager; require_once "vendor/autoload.php"; $cm = new ClientManager('path/to/config/imap.php'); /** @var \Webklex\PHPIMAP\Client $client */ $client = $cm->account('account_identifier'); //Connect to the IMAP Server $client->connect(); //Get all Mailboxes /** @var \Webklex\PHPIMAP\Support\FolderCollection $folders */ $folders = $client->getFolders(); //Loop through every Mailbox /** @var \Webklex\PHPIMAP\Folder $folder */ foreach($folders as $folder){ //Get all Messages of the current Mailbox $folder /** @var \Webklex\PHPIMAP\Support\MessageCollection $messages */ $messages = $folder->messages()->all()->get(); /** @var \Webklex\PHPIMAP\Message $message */ foreach($messages as $message){ echo $message->getSubject().'<br />'; echo 'Attachments: '.$message->getAttachments()->count().'<br />'; echo $message->getHTMLBody(); //Move the current Message to 'INBOX.read' if($message->move('INBOX.read') == true){ echo 'Message has been moved'; }else{ echo 'Message could not be moved'; } } }
赞助商
测试
要运行测试,请执行以下命令
composer test
快速测试 / 静态测试
要禁用所有需要实时邮箱的测试,请将 phpunit.xml.dist
复制到 phpunit.xml
并调整配置
<php> <env name="LIVE_MAILBOX" value="false"/> </php>
完整测试 / 实时邮箱测试
要运行所有测试,您需要提供一个有效的 imap 配置。
要提供有效的 imap 配置,请将 phpunit.xml.dist
复制到 phpunit.xml
并调整配置
<php> <env name="LIVE_MAILBOX" value="true"/> <env name="LIVE_MAILBOX_DEBUG" value="true"/> <env name="LIVE_MAILBOX_HOST" value="mail.example.local"/> <env name="LIVE_MAILBOX_PORT" value="993"/> <env name="LIVE_MAILBOX_VALIDATE_CERT" value="false"/> <env name="LIVE_MAILBOX_QUOTA_SUPPORT" value="true"/> <env name="LIVE_MAILBOX_ENCRYPTION" value="ssl"/> <env name="LIVE_MAILBOX_USERNAME" value="[email protected]"/> <env name="LIVE_MAILBOX_PASSWORD" value="foobar"/> </php>
测试账户不应该包含任何重要数据,因为它将在测试过程中被删除。此外,测试账户应该能够创建新文件夹、移动消息,并且在测试期间不应被任何其他应用程序使用。
建议为此目的使用专门的测试账户。您可以使用提供的 Dockerfile
创建用于测试目的的 imap 服务器。
构建 docker 镜像
cd .github/docker docker build -t php-imap-server .
运行 docker 镜像
docker run --name imap-server -p 993:993 --rm -d php-imap-server
停止 docker 镜像
docker stop imap-server
已知问题
支持
如果您遇到任何问题或发现任何错误,请不要犹豫,创建一个新的 问题。但是,请注意,可能需要一些时间才能得到答复。与主题无关、粗鲁或侮辱性的问题将被无通知删除。
如果您需要 商业 支持,请随时通过 [email protected] 发送邮件。
一点注意事项
如果您在问题中编写源代码,请考虑正确格式化。这使得阅读更加愉快,人们更有可能评论和帮助 :)
and people are more likely to comment and help :)
```php
echo 'your php code...';
```
将变成
echo 'your php code...';
功能 & pull 请求
每个人都可以为此项目做出贡献。每个 pull 请求都将被考虑,但也可能会被拒绝。
为了防止不必要的劳动,请考虑创建一个 特性问题
首先,如果您打算进行较大的更改。当然,如果您只是希望添加一个特性,也可以创建一个新的 特性问题 ;)
变更日志
请查看 变更日志 获取有关最近更改的更多信息。
安全
如果您发现任何安全问题,请发送电子邮件至 [email protected] 而不是使用问题跟踪器。
致谢
许可
MIT 许可证 (MIT)。请参阅 许可文件 获取更多信息。