php - PHPMailer 似乎不适用于 Hostgator 托管
问题描述
我在带有 Hostgator 托管业务帐户的核心 PHP 上使用 PHPMailer,并且我在 SMTPDebug 中收到以下错误:
2020-01-13 13:16:54 SERVER -> CLIENT: 220-gator4001.hostgator.com ESMTP Exim 4.92 #2 Mon, 13 Jan 2020 07:16:54 -0600 220-We do not authorize the use of this system to transport unsolicited, 220 and/or bulk e-mail.
2020-01-13 13:16:54 CLIENT -> SERVER: EHLO www.domainname.com
2020-01-13 13:16:54 SERVER -> CLIENT: 250-gator4001.hostgator.com Hello www.domainname.com [192.185.16.229]250-SIZE 52428800250-8BITMIME250-PIPELINING250-AUTH PLAIN LOGIN250 HELP
2020-01-13 13:16:54 CLIENT -> SERVER: AUTH LOGIN
2020-01-13 13:16:54 SERVER -> CLIENT: 334 VXNlcm5hbWU6
2020-01-13 13:16:54 CLIENT -> SERVER: ZG9ub3RyZXBseUBjaGFpbnRoZWFwcC5jb20=
2020-01-13 13:16:54 SERVER -> CLIENT: 334 UGFzc3dvcmQ6
2020-01-13 13:16:54 CLIENT -> SERVER: YThoZkhON3FpKG9A
2020-01-13 13:16:54 SERVER -> CLIENT: 235 Authentication succeeded
2020-01-13 13:16:54 CLIENT -> SERVER: MAIL FROM:<donotreply@domainname.com>
2020-01-13 13:16:54 SERVER -> CLIENT: 250 OK
2020-01-13 13:16:54 CLIENT -> SERVER: RCPT TO:<my@emailaddress.com>
2020-01-13 13:16:54 SERVER -> CLIENT: 250 Accepted
2020-01-13 13:16:54 CLIENT -> SERVER: DATA
2020-01-13 13:16:54 SERVER -> CLIENT: 354 Enter message, ending with "." on a line by itself
2020-01-13 13:16:54 CLIENT -> SERVER: Date: Mon, 13 Jan 2020 16:16:54 +0300
2020-01-13 13:16:54 CLIENT -> SERVER: To: Taha Khan <my@emailaddress.com>
2020-01-13 13:16:54 CLIENT -> SERVER: From: Chain <donotreply@domainname.com>
2020-01-13 13:16:54 CLIENT -> SERVER: Subject: Chain account please activate your account
2020-01-13 13:16:54 CLIENT -> SERVER: Message-ID: <KvZPwFu2gMzFcs5f9XiBML51sazZsNQRXMqmxiuo@www.domainname.com>
2020-01-13 13:16:54 CLIENT -> SERVER: X-Mailer: PHPMailer 6.0.1 (https://github.com/PHPMailer/PHPMailer)
2020-01-13 13:16:54 CLIENT -> SERVER: MIME-Version: 1.0
2020-01-13 13:16:54 CLIENT -> SERVER: Content-Type: multipart/alternative;
2020-01-13 13:16:54 CLIENT -> SERVER: tboundary="b1_KvZPwFu2gMzFcs5f9XiBML51sazZsNQRXMqmxiuo"
2020-01-13 13:16:54 CLIENT -> SERVER: Content-Transfer-Encoding: 8bit
2020-01-13 13:16:54 CLIENT -> SERVER:
2020-01-13 13:16:54 CLIENT -> SERVER: This is a multi-part message in MIME format.
2020-01-13 13:16:54 CLIENT -> SERVER: --b1_KvZPwFu2gMzFcs5f9XiBML51sazZsNQRXMqmxiuo
2020-01-13 13:16:54 CLIENT -> SERVER: Content-Type: text/plain; charset=us-ascii
2020-01-13 13:16:54 CLIENT -> SERVER:
2020-01-13 13:16:54 CLIENT -> SERVER: This is a test html email
2020-01-13 13:16:54 CLIENT -> SERVER:
2020-01-13 13:16:54 CLIENT -> SERVER: --b1_KvZPwFu2gMzFcs5f9XiBML51sazZsNQRXMqmxiuo
2020-01-13 13:16:54 CLIENT -> SERVER: Content-Type: text/html; charset=us-ascii
2020-01-13 13:16:54 CLIENT -> SERVER:
2020-01-13 13:16:54 CLIENT -> SERVER: This is a test html email
2020-01-13 13:16:54 CLIENT -> SERVER:
2020-01-13 13:16:54 CLIENT -> SERVER:
2020-01-13 13:16:54 CLIENT -> SERVER: --b1_KvZPwFu2gMzFcs5f9XiBML51sazZsNQRXMqmxiuo--
2020-01-13 13:16:54 CLIENT -> SERVER:
2020-01-13 13:16:54 CLIENT -> SERVER: .
2020-01-13 13:16:54 SERVER -> CLIENT: 250 OK id=1iqzaQ-000Ars-TL
2020-01-13 13:16:54 CLIENT -> SERVER: QUIT
2020-01-13 13:16:54 SERVER -> CLIENT: 221 gator4001.hostgator.com closing connection
日志的第一行显示我们不授权使用该系统来传输未经请求的 220 和/或批量电子邮件。但同时 PHPMailer 正在给我回复Mail sent。
这里可能是什么问题,我该如何解决?
此外,我使用了我的实际电子邮件地址和实际网站地址,而不是my@emailaddress.com和domainname.com 。只是在这里写这个,显然人们指出了这里最奇怪的东西哈哈。
编辑
请在下面找到php代码:
<?php
use PHPMailer\PHPMailer\PHPMailer;
use PHPMailer\PHPMailer\Exception;
require 'Exception.php';
require 'PHPMailer.php';
require 'SMTP.php';
$mail = new PHPMailer(true);
try {
//Server settings
$mail->SMTPDebug = 2;
$mail->isSMTP();
$mail->Host = 'domainname.com';
$mail->SMTPAuth = true;
$mail->Username = 'donotreply@domainname.com';
$mail->Password = 'mypassword';
$mail->SMTPSecure = 'ssl';
$mail->Port = 465;
//Recipients
$mail->setFrom('donotreply@domainname.com', 'MyTestEmail');
$mail->addAddress('info@domainname.com', 'Khan');
//Content
$mail->isHTML(true);
$mail->Subject = 'Test Email body';
$mail->Body = 'Test Email body';
$mail->AltBody = 'Test Email body';
$mail->send();
return "SUCCESS";
} catch (Exception $e) {
return "FAIL";
// Use the line below to display error
// echo 'Mailer Error: ' . $mail->ErrorInfo;
}
?>
** 更新 **
我在 donotreply@domainname.com 上收到了退回的电子邮件,其中包含以下错误:
The mail system
<info@domainname.com>: host mail.domainname.com[192.185.30.71] said:
550-Verification failed for <donotreply@domainname.com> 550-No Such User
Here 550 Sender verify failed (in reply to RCPT TO command)
Reporting-MTA: dns; gateway21.websitewelcome.com
X-Postfix-Queue-ID: 14259400E4AA1
X-Postfix-Sender: rfc822; donotreply@domainname.com
Arrival-Date: Mon, 13 Jan 2020 08:02:26 -0600 (CST)
Final-Recipient: rfc822; info@domainname.com
Original-Recipient: rfc822;info@domainname.com
Action: failed
Status: 5.0.0
Remote-MTA: dns; mail.domainname.com
Diagnostic-Code: smtp; 550-Verification failed for <donotreply@domainname.com>
550-No Such User Here 550 Sender verify failed
解决方案
问题基本上与新创建的电子邮件 donotreply@domainname.com 本身有关。使用 PHPMailer 测试的前两个电子邮件地址在收件箱中被退回。如果您面临与我完全相同的问题,那么我建议您进行以下故障排除:
确保 Debug 未设置为 0
$mail->SMTPDebug = 2
测试您的代码并检查 PHPMailer 最后是否触发成功。
检查 PHPMailer 是否回显成功
正如@ADyson 所指出的,以下错误/通知并不意味着PHPMailer 不工作。
服务器 -> 客户端:220-gator4001.hostgator.com ESMTP Exim 4.92 #2 Mon, 13 Jan 2020 07:16:54 -0600 220-我们不授权使用此系统传输未经请求的 220 和/或批量电子邮件-邮件。
其次,通过向不同服务器上的不同域发送电子邮件来测试您的代码
测试向托管在另一台服务器上的 Gmail、Hotmail、Yahoo、其他电子邮件发送电子邮件。
检查您的收件箱是否有任何退回的邮件。
如果您收到退回的消息;可以肯定的是 PHPMailer 工作正常。
通过在退回的电子邮件中向他们提供错误详细信息,联系您的主机以获取更多详细信息。
我的问题已由 hostgator 解决,因为发送到少数电子邮件地址的电子邮件会反弹,而它与 Gmail 和 Hotmail 完美配合
推荐阅读
- c - 如何将数字存储在结构数组中
- laravel - 在模型(父)上应用 WHERE 子句时出错,然后以雄辩的方式获取其相关的模型(子)数据
- c# - Dapper 中的地图数据库和模型
- c# - 如何防止在 Windows 窗体应用程序构建中创建 .exe.config (Visual Studio Community 2019 - C#)
- cypress - 我如何在 cypress 中使用 xpath 上传文件
- spring-boot - 从另一台服务器获取 HttpServletRequest 并将 cookie 设置为 httpServletResponse 并发送回源服务器是请求来的
- android - 当库使用 android 组件并且应用程序使用 androidx 组件时,Jetifier 不工作
- docker - 负载均衡的 docker-exec
- c++ - 遵循官方 direct2d 示例,但出现访问冲突错误
- php - 自定义复选框在 Woocommerce 结帐中显示或隐藏自定义通知