imiphp / imi-email-blacklist
imi 框架邮箱域名黑名单组件,支持自动更新临时邮箱域名列表。
v2.1.2
2024-02-19 02:43 UTC
Requires
- yurunsoft/yurun-http: ^4.4
Requires (Dev)
- imiphp/imi: 2.1.x-dev
- imiphp/imi-swoole: 2.1.x-dev
- php-cs-fixer/shim: ~3.22.0
- phpstan/phpstan: ~1.8.0
- phpunit/phpunit: ~9.6
- swoole/ide-helper: ^4.8|^5.0
- yurunsoft/ide-helper: ~1.0
This package is auto-updated.
Last update: 2024-12-19 04:39:32 UTC
README
介绍
imi 框架邮箱域名黑名单组件,支持自动更新临时邮箱域名列表。
安装
composer require imiphp/imi-email-blacklist:~2.1.0
使用说明
数据更新
配置:
@app.beans
:
[ \Imi\Email\BlackList\EmailBlackListHandler::class => [ 'handler' => \Imi\Email\BlackList\Handler\RedisHandler::class, // 数据处理器,目前仅支持 Redis,你也可以实现 \Imi\Email\BlackList\IHandler 接口自定义处理器 ], \Imi\Email\BlackList\EmailBlackListCrawler::class => [ 'enable' => true, // 是否启用 // 采集器列表 // 你也可以实现 \Imi\Email\BlackList\Contract\IEmailBlackListCrawler 接口自定义采集器 'crawlers' => [ \Imi\Email\BlackList\IvoloDisposableEmailDomainsCrawler::class, // 数据来源:https://github.com/ivolo/disposable-email-domains/raw/master/index.json ], ], // handler 配置 \Imi\Email\BlackList\Handler\RedisHandler::class => [ 'key' => 'imi:email:blacklist', // 存储数据的键名 'poolName' => null, // 连接池 ], ]
上面展示的是默认配置,默认不配置也可以使用
定时自动采集:
由于列表频繁更新可能性不大,固定 1 小时采集一次。你必须启用定时任务进程。
手动更新采集:
运行命令:vendor/bin/imi-swoole emailBlackList/crawl
imi-swoole
也可以替换为其它容器的启动文件
自定义管理域名
$handler = \Imi\Email\BlackList\Util\EmailBlackListUtil::getHandler(); $handler->add(['example.com']); // 批量增加 $handler->remove(['example.com']); // 批量删除 $handler->clear(); // 清空 $handler->has('example.com'); // 是否存在 $handler->count(); // 统计数量 $handler->list(); // 获取列表 $handler->list('.com'); // 关键词搜索 // 分页 // 注意:RedisHandler 返回数据数量可能不一定等于 $count $page = 1; $count = 10; $handler->list('', $page, $count);
验证器
注解:Imi\Email\BlackList\Validate\Annotation\EmailBlackList
<?php declare(strict_types=1); namespace app\Module\Service; use Imi\Email\BlackList\Validate\Annotation\EmailBlackList; use Imi\Validate\Annotation\AutoValidation; class TestService { /** * @AutoValidation * * @EmailBlackList(name="email") */ public function testEmail(string $email): void { } }
手动验证
// 不在黑名单中返回 true,否则返回 false \Imi\Email\BlackList\Util\EmailBlackListUtil::validateEmail('a@example.com');
免费技术支持
技术支持详见:https://doc.imiphp.com/v2.1/base/support.html
运行环境
版权信息
imi-email-blacklist
遵循 MulanPSL-2.0 开源协议发布,并提供免费使用。
捐赠
开源不求盈利,多少都是心意,生活不易,随缘随缘……