问题:
我正在使用带有 Postfix 的 OpenDKIM。邮件是使用以下代码在 PHP 中生成的,然后使用以下代码发送mail()
:
// message
$message = "--$hash".PHP_EOL;
$message .= "Content-Type: text/plain; charset=\"iso-8859-1\"".PHP_EOL;
$message .= "Content-Transfer-Encoding: base64".PHP_EOL.PHP_EOL;
$message .= base64_encode($body).PHP_EOL.PHP_EOL;
$message .= "--$hash".PHP_EOL;
OpenDKIM 适用于长度小于 742 个字符的任何消息,但如果消息是 742 个字符或更多字符,Google 会报告 DKIM“ body hash did not verify
”。
查看 DKIM 和 Google,我找不到任何有关导致此问题的信息。我尝试了多条 741 个字符(全部通过)和多条 742 个字符(全部失败)的消息。
错误:
唯一的错误是谷歌收到的电子邮件(它说它无法验证):
dkim=neutral (body hash did not verify) header.i=@mailer.example.com;
/var/log/maillog
在成功和不成功的电子邮件中包含以下(或类似内容):
Nov 5 00:58:57 ip-XX-XX-XX-XX opendkim[3953]: 7D2946081A: DKIM-Signature field added (s=default, d=mailer.example.com)
解决方案:
根据@Adrien Lebner 下面的解决方案,这是一个简单的改变
base64_encode($body)
至
chunk_split(base64_encode($body), 76, PHP_EOL)
解决了这个问题。