CakePhp:Cake Email AfterSend事件

时间:2015-05-09 09:06:20

标签: php email cakephp

大家早上好,

我目前正在使用CakePHP。
我希望在CakePHP发送电子邮件后设置一个事件,因为我想在数据库中存储此电子邮件的日志,其中包含发件人,收件人,主题和正文的单独列。 目前我正在使用本机日志系统(电子邮件的所有标题和正文在同一个地方),但是调试变得太乱了。

CakeEmail类不提供回调方法,如果不编辑CakeEmail类,我找不到任何调用此类事件的方法。
当然,我可以创建一个扩展本机CakeEmail类的 MyCakeEmail 类,但这意味着在代码中更改每个新的CakeEmail()

你有什么建议?
非常感谢!

(抱歉英语不好,不是我的母语)

1 个答案:

答案 0 :(得分:2)

使用自定义记录器:

Implement your own logger具有您想要的数据库功能,并在引导程序中为电子邮件范围配置它,这是电子邮件日志的默认范围或更改电子邮件类配置中的整个日志记录。 See this part of the email class.

1161:         $contents = $this->transportClass()->send($this);
1162:         if (!empty($this->_config['log'])) {
1163:             $config = array(
1164:                 'level' => LOG_DEBUG,
1165:                 'scope' => 'email'
1166:             );
1167:             if ($this->_config['log'] !== true) {
1168:                 if (!is_array($this->_config['log'])) {
1169:                     $this->_config['log'] = array('level' => $this->_config['log']);
1170:                 }
1171:                 $config = $this->_config['log'] + $config;
1172:             }
1173:             CakeLog::write(
1174:                 $config['level'],
1175:                 PHP_EOL . $contents['headers'] . PHP_EOL . $contents['message'],
1176:                 $config['scope']
1177:             );
1178:         }

使用你自己的班级 - 但做得不错

  

当然我可以创建一个扩展本地CakeEmail类的MyCakeEmail类,但这意味着在代码中更改每个新的CakeEmail()。

您可以使用自己的电子邮件课程。但是,在任何情况下,在代码中到处都new SomeClass()并不是一件好事。你只知道原因。另一个不容易测试的原因。

而是在继承链的上层(AppController,AppModel ...)的某些类中执行此操作:

public function getEmailInstance($config = null) {
    return new MyEmailClass($config);
}

这使您可以简单地更改班级"全球"并在测试中模拟该方法。

如果您正在使用php 5.4(或5.5,现在还不确定),您也可以使用它的特性,并仅在需要该功能的类中使用它。