首页 > 解决方案 > 当我可以通过 PHP 脚本发送电子邮件时,为什么我不能通过 Wordpress 发送电子邮件?

问题描述

我已将运行 4.9.8 版的 Wordpress 服务器从 Ubuntu 迁移到 CentOS,并且来自 Wordpress 的电子邮件似乎无法正确发送。我正在通过创建与各种电子邮件地址关联的新用户来测试发送电子邮件。

我已经安装了 Postfix 并将其配置为尽可能与原始配置匹配。我这样说是因为 Postfix 的实现方式有一些细微的差别。

我可以通过命令行和通过托管在与 Wordpress 相同的服务器 (php-fpm) 上的 PHP 脚本向各种地址发送电子邮件。

但是,当我尝试将电子邮件(通过在 wp-admin 中创建新用户)发送到 Wordpress 中的相同地址时,它们不会到达收件人。我检查了 Wordpress 配置文件,没有看到任何覆盖默认邮件操作的内容。当通过我的 PHP 脚本触发电子邮件时,/var/log/maillog 中没有新条目:

<?php
// the message
$msg = "First line of text\nSecond line of text";

// use wordwrap() if lines are longer than 70 characters
$msg = wordwrap($msg,70);

// send email
mail("me@{mydomain}","My subject",$msg);
?>

从 Wordpress 触发电子邮件后也没有条目。

编辑:我打开了对日志文件的调试并添加了一个函数来捕获 wp_mail 错误。这是我在尝试时看到的错误:

(
            [wp_mail_failed] => Array
                (
                    [0] => Invalid address:  (setFrom) wordpress@{mydomain}
                )

        )

发件人电子邮件地址与原始服务器中的相同。

编辑2:

我在functions.php 中添加了更多自定义代码来设置发件人,并且我尝试了几个不同的发件人电子邮件地址——它们都是有效的电子邮件地址。所有这些都因“无效地址”错误而失败。奇怪的是 PHP 的邮件功能将电子邮件作为 wordpress@{mydomain} 发送,并且工作正常。

标签: phpwordpresspostfix-mta

解决方案


我最初的解决方案是将 class-phpmailer.php 直接更改为“noregex”,但感谢 Wordpress 论坛上的@diondesigns,我发现我可以在主题的 functions.php 中添加一行:

add_filter( 'wp_mail_from', function($from){PHPMailer::$validator = 'noregex'; return $from;} );

现在电子邮件发送正常。

更新:

我想补充一点,这里的主要问题是 PHP 是用 PCRE2 编译的,而不是 PCRE。这破坏了 PHPMailer 中的 validateAddress。转到编译了 PCRE 的 PHP 版本后,我不再看到该问题。我推荐这条路径而不是解决方法。


推荐阅读