在寻找解决方案的过程中,我发现了 jakub-kaspar/mailer 这个库,它是一个基于 Nette 框架的邮件发送和日志记录工具。它的主要功能包括邮件发送、邮件过滤和详细的日志记录,能够满足我的需求。
首先,使用 Composer 安装这个库非常简单,只需运行以下命令:
composer require jakub-kaspar/mailer
安装完成后,接下来需要对库进行配置。jakub-kaspar/mailer 库的配置文件是 config.neon,在这个文件中,我们需要定义一些参数:
- db:数据库配置,这是必需的参数,用于存储邮件日志。
- filters:邮件过滤器配置,也是一个必需参数,用于对邮件进行预处理。
- mailer:邮件发送器配置,这是可选的参数,可以使用任何实现了 Nette 的 IMailer 接口的实例。
- maxInBody:可选参数,用于指定在邮件正文中可以发送的报告邮件数量。
- maxReport:可选参数,用于指定报告文件的最大大小(以 .txt 文件形式)。
配置完成后,我们可以开始使用这个库来发送邮件和记录日志。以下是一个简单的示例代码,展示如何使用这个库:
use JakubKaspar\Mailer\EmailLogModel;
use JakubKaspar\Mailer\Mailer;
$mailer = new Mailer($config); // $config 是从 config.neon 文件中读取的配置
$emailLogModel = new EmailLogModel($config);
$mailer->send('recipient@example.com', 'Subject', 'Message');
$emailLogModel->logEmail('recipient@example.com', 'Subject', 'Message');此外,jakub-kaspar/mailer 库还支持自定义过滤器。如果你需要对邮件进行特定的处理,可以实现 IFilter 接口,然后在 config.neon 文件中注册你的过滤器。例如:
use JakubKaspar\Mailer\IFilter;
class MyCustomFilter implements IFilter {
public function filter($email) {
// 自定义过滤逻辑
return $email;
}
}然后在 config.neon 文件中添加:
filters:
myCustomFilter: MyCustomFilter最后,关于数据库的配置,jakub-kaspar/mailer 库已经预设了 EmailLogModel 中的表结构。如果你希望使用自己的数据库结构,可以通过 SQL 命令创建表:
CREATE TABLE `email_log` ( `id` int(10) unsigned NOT NULL AUTO_INCREMENT, `created` datetime DEFAULT NULL, `from` varchar(100) DEFAULT NULL, `to` varchar(100) DEFAULT NULL, `subject` varchar(255) DEFAULT NULL, `message` text, `message_object` longblob, `is_sent` tinyint(1) unsigned NOT NULL DEFAULT '0', `number_of_tries` tinyint(3) unsigned NOT NULL DEFAULT '0', `exception` varchar(255) DEFAULT NULL, `is_reported` tinyint(1) NOT NULL DEFAULT '0', PRIMARY KEY (`id`), KEY `is_sent` (`is_sent`), KEY `number_of_tries` (`number_of_tries`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8
通过使用 jakub-kaspar/mailer 库,我成功地解决了邮件日志记录的问题。这个库不仅简化了邮件发送和日志记录的过程,还提供了灵活的配置选项和自定义过滤器功能,大大提高了开发效率和系统的可维护性。无论是小型项目还是大型应用程序,jakub-kaspar/mailer 都是一个值得推荐的邮件处理解决方案。










