PHPMailer 生成 PHP 警告:stream_socket_enable_crypto(): Peer certificate does not match expected

新手上路,请多包涵

我在 PHP 5.6 上使用 PHPMailer,在 PHP 5.6 中增加的证书安全性当然很有趣。

我正在尝试向 Dreamhost 上托管的域发送测试消息,从 PHPMailer 返回的错误是:无法连接到 SMTP 主机。

不过,这个错误是不对的,我启用了日志记录,这就是实际发生的情况。

连接:打开到 mx1.sub4.homie.mail.dreamhost.com:25, timeout=30, options=array ( ) 连接:打开 S: 220 homiemail-mx32.g.dreamhost.com ESMTP

C: EHLO s81a.ikbb.com

S:250-homiemail-mx32.g.dreamhost.com 250-PIPELINING 250-SIZE 40960000 250-ETRN 250-STARTTLS 250-ENHANCEDSTATUSCODES 250 8BITMIME

C:开始TLS

S: 220 2.0.0 准备启动 TLS

C:退出

S:SMTP 错误:QUIT 命令失败:连接:关闭

我不明白为什么 PHPMailer 只是放弃,在它应该开始发送消息时发出 QUIT 命令。我从另一个日志中得到了另一个线索:

PHP 警告:stream_socket_enable_crypto(): Peer certificate CN= *.mail.dreamhost.com' did not match expected CN= mx1.sub4.homie.mail.dreamhost.com’ 在 /home/ikbb/domains/dev.ikbb.com/public_html/includes/phpmailer/ 5.2.10/class.smtp.php

如果我使用一些自定义选项来阻止验证他们正在使用的证书,我可以让它继续。这是我所拥有的:

         $mail->SMTPOptions = array (
        'ssl' => array(
            'verify_peer'  => false,
            'verify_peer_name'  => false,
            'allow_self_signed' => true));

如果我将 SMTPOptions 放在那里并跳过对等验证,则消息正常 - 在 PHP 中根本没有警告。

如何捕获该错误,以便我知道存在问题但仍发送消息?

原文由 Rob Gunsuka 发布,翻译遵循 CC BY-SA 4.0 许可协议

阅读 1k
2 个回答

我遇到了同样的问题,我在 PHPMailer 文档 中找到了答案。

PHP 5.6 证书验证失败

与早期版本相比,PHP 5.6 验证 SSL 连接上的证书。如果您要连接的服务器的 SSL 配置不正确,您将收到如下错误:

 Warning: stream_socket_enable_crypto(): SSL operation failed with code 1.
OpenSSL Error messages: error:14090086:SSL routines:SSL3_GET_SERVER_CERTIFICATE:certificate verify failed

解决此问题的正确方法是用一个好的证书替换无效、配置错误或自签名的证书。 如果做不到这一点,您可以通过 PHPMailer 5.2.10 中引入的 SMTPOptions 属性允许不安全的连接(可以通过在早期版本中继承 SMTP 类来做到这一点),但不建议这样做:

 $mail->SMTPOptions = array(
    'ssl' => array(
        'verify_peer' => false,
        'verify_peer_name' => false,
        'allow_self_signed' => true
    )
);

您也可以在 php.ini 中全局更改这些设置,但这是一个非常糟糕的主意; PHP 5.6 做出这个改变是有充分理由的。

有时这种行为并不那么明显;有时加密失败可能会在客户端尝试执行 STARTTLS 后立即发出 QUIT 时出现。如果您看到这种情况,您应该检查您的证书或验证设置的状态。

原文由 Jesús Amieiro 发布,翻译遵循 CC BY-SA 3.0 许可协议

如果您刚刚迁移到不同的服务器,很可能您可以通过禁用 WHM 的 SMTP 限制来解决此问题:

在此处输入图像描述

原文由 Jeswin Libay 发布,翻译遵循 CC BY-SA 4.0 许可协议

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题