ホームページ >バックエンド開発 >PHPチュートリアル >Linux サーバーで PHPMailer が電子メールの送信に失敗する問題を解決するためのヒント
この記事では、主に Linux サーバーで PHPMailer がメールを送信できない問題を解決する方法をサンプルコードを通じて詳しく紹介します。必要な方は参考にしてください。下に。 。
要件
サーバーを変更した後、メール送信機能が失敗していることがわかりました。元のサーバーは正常でしたが、何か問題があるはずなので、確認してみることにしました。電子メールの送信には PHPMailer と SMTP を使用します。
トラブルシューティングプロセス
まず第一に、PHP はソケット拡張を有効にする必要があります。phpinfo ページを確認したところ、有効になっていました。
確認したところ、openssl も有効になっていました (qq メールボックスを取得したため)。テストするため)、問題ありません:
次に、allow_url_fopen を見てください。オンになっています。問題ありません:
機能は無効になっていますか?無効ではありません、問題ありません:
それから、私が疑問に思っていたのは、ポートが占有されているということです。
実行します: netstat -tnlp
netstat -tnlp
第一条就是这玩意:
25端口被占用,被一个叫master的玩意占了,好家伙,看看是什么东西,运行ps -f -p 1818
看一下结果,1818为当前这个程序的进程号PID,可以看到是:
是postfix这个东西在运行,可能搭建环境的时候不小心给装了。
postfix是个什么东西?
postfix是一款运行在Linux环境下免费的邮件服务器,或者称为MTA(Mail Transfer Agent),其它类似的有Sendmail、Qmail、exim及Zmailer 等。所以Postfix就是一个搭邮件服务器的。那这玩意肯定是冲突了,我们要通过25端口请求外部的邮件服务器,而本地用25端口运行了一个邮件服务器,这个是不行的估计.
尝试解决问题
我们尝试一下用我们这个邮件服务器去发邮件,而不是用外部服务器(比如之前用阿里云企业邮),放了一小段测试代码到PHPMailer目录同级下:
<?php header("content-type:text/html;charset=utf-8"); require 'PHPMailer/class.phpmailer.php'; try { $mail = new PHPMailer(true); $mail->IsSMTP(); $mail->CharSet='UTF-8'; $mail->SMTPAuth = true; $mail->Port = 25; $mail->Host = '127.0.0.1';//邮箱smtp地址 $mail->Username = 'gzp@gzpblog.com';//你的邮箱账号 $mail->Password = '扒拉扒拉。。。';//你的邮箱密码 $mail->From = 'gzp@gzpblog.com';//你的邮箱账号 $mail->FromName = '锅子'; $to = "扒拉扒拉@qq.com"; $mail->AddAddress($to); $mail->Subject = "test"; $mail->Body = 'hello!'; $mail->WordWrap = 80; $mail->IsHTML(true); $mail->Send(); echo "success!"; } catch (phpmailerException $e) { echo "邮件发送失败:".$e->errorMessage(); }
通过25端口的本地服务器发送邮件,运行这个页面,发现不行,报错不能够验证,说明这其中还有一些配置要弄,暂时行不通,不往下深究本地服务器发送了,我们尝试一下换回:
$mail->Host = ‘smtp.mxhichina.com'; //阿里云的邮箱smtp地址
试一下,还是不行:
没办法连接到SMTP。那我们把25端口的postfix服务器杀掉, 执行kill 1818(当前postfix的PID),再执行一次,还是同样错误,无法连接上。这就奇了怪了,25端口没有程序运行了,还不行。
可能的原因
查到有可能是因为ipv6的原因,phpMailer在进行smtp服务器DNS解析时,得到了IP v6地址,然后与IP v6解析到的地址进行连接,导致连接失败。
我试一下:
ip -6 addr show
ポート 25 はマスターと呼ばれるものによって占有されています。いいですね、それが何であるかを見てみましょう。ps -f -p 1818 code> を実行して結果を見てください, 1818 は現在のプログラムのプロセス番号 PID で、次のように表示されます:
Postfix が実行されています。環境設定時に誤ってインストールされた可能性があります。 接尾辞とは何ですか?
Postfix は、Linux 環境で実行される無料のメール サーバー、または MTA (Mail Transfer Agent) の他に、Sendmail、Qmail、exim、Zmailer などがあります。つまりPostfixはメールサーバーです。その場合、これは競合しているはずです。ポート 25 経由で外部メール サーバーをリクエストする必要がありますが、ローカル メール サーバーはポート 25 で実行されています。これはおそらく不可能です
試してみましょう。 using our このメール サーバーは、外部サーバーを使用する代わりに電子メールを送信するために使用されます (たとえば、以前は Alibaba Cloud Enterprise Mail が使用されていました)。PHPMailer ディレクトリの同じレベルに小さなテスト コードを置きました:
<?php header("content-type:text/html;charset=utf-8"); require 'PHPMailer/class.phpmailer.php'; try { $mail = new PHPMailer(true); $mail->IsSMTP(); $mail->CharSet='UTF-8'; $mail->SMTPAuth = true; $mail->SMTPSecure = 'ssl'; $mail->Port = 465; $mail->Host = 'smtp.mxhichina.com';//邮箱smtp地址 $mail->Username = 'gzp@gzpblog.com';//你的邮箱账号 $mail->Password = '扒拉扒拉。。。';//你的邮箱密码 $mail->From = 'gzp@gzpblog.com';//你的邮箱账号 $mail->FromName = '锅子'; $to = "扒拉扒拉@qq.com"; $mail->AddAddress($to); $mail->Subject = "test"; $mail->Body = 'hello!'; $mail->WordWrap = 80; //$mail->AddAttachment("f:/test.png"); //可以添加附件 $mail->IsHTML(true); $mail->Send(); echo "success!"; } catch (phpmailerException $e) { echo "邮件发送失败:".$e->errorMessage(); //测试的时候可以去掉此行的注释 }
🎜🎜🎜 試してみてください。しかし、まだ動作しません:🎜🎜🎜🎜できませんSMTPに接続します。次に、ポート 25 の Postfix サーバーを強制終了し、kill 1818 (現在の Postfix の PID) を実行して、再度実行しても同じエラーが発生し、接続できません。これは奇妙です。ポート 25 ではプログラムが実行されていないため、まだ動作しません。 🎜🎜🎜考えられる原因🎜🎜🎜 phpMailerがsmtpサーバー上でDNS解決を行う際に、IP v6アドレスを取得し、IP v6で解決されたアドレスで接続するため、接続ができない可能性があることが判明しました。失敗する。 🎜🎜試してみます: 🎜🎜ip -6 addr show
🎜🎜🎜🎜🎜何も、それは問題ではありません。 🎜🎜その理由は何ですか? 🎜🎜🎜🎜問題を解決🎜🎜🎜🎜ポート25が利用できないため、他のポートを試してポート465を試してみることができるかどうかを考えました。 🎜🎜ポート 465 (SMTPS): ポート 465 は、SMTPS (SMTP-over-SSL) プロトコル サービス用に開かれています。これは、SSL セキュリティ プロトコルの非対称性を継承する SMTP プロトコルの一種です。暗号化による高いセキュリティと信頼性により、メールの漏洩を防ぐことができます。 SMTPS は SMTP プロトコルと同様に電子メールの送信にも使用されますが、ハッカーによる電子メールの傍受や漏洩を防ぐためにより安全であり、電子メール送信者の否認防止機能も実装できます。送信者が送信したメールを送信後に削除したり、そのようなメールが送信されたことを拒否したりすることを防ぎます。 🎜🎜🎜ポート 465 の方が良いと思われるので、次のコマンドを試してみました。
sbin/iptables -I OUTPUT -p tcp –dport 465 -j ACCEPT
打通465端口
/etc/rc.d/init.d/iptables save
保存
service iptables restart
重启
/etc/init.d/iptables status
查看需要打开的端口是否生效?
似乎可行,现在尝试一下,用SMTP的465SSL连接方式来发送邮件,稍微改了一下测试代码:
<?php header("content-type:text/html;charset=utf-8"); require 'PHPMailer/class.phpmailer.php'; try { $mail = new PHPMailer(true); $mail->IsSMTP(); $mail->CharSet='UTF-8'; $mail->SMTPAuth = true; $mail->SMTPSecure = 'ssl'; $mail->Port = 465; $mail->Host = 'smtp.mxhichina.com';//邮箱smtp地址 $mail->Username = 'gzp@gzpblog.com';//你的邮箱账号 $mail->Password = '扒拉扒拉。。。';//你的邮箱密码 $mail->From = 'gzp@gzpblog.com';//你的邮箱账号 $mail->FromName = '锅子'; $to = "扒拉扒拉@qq.com"; $mail->AddAddress($to); $mail->Subject = "test"; $mail->Body = 'hello!'; $mail->WordWrap = 80; //$mail->AddAttachment("f:/test.png"); //可以添加附件 $mail->IsHTML(true); $mail->Send(); echo "success!"; } catch (phpmailerException $e) { echo "邮件发送失败:".$e->errorMessage(); //测试的时候可以去掉此行的注释 }
执行,成功!右下角弹出了QQ邮件的提醒。
总结
PHPMailer通过465端口进行更安全的SMTPS协议发送邮件
可以修改:
$mail->Port = 465;
为:
$mail->SMTPSecure = 'ssl'; $mail->Port = 465;
即可。
以上就是Linux服务器下PHPMailer发送邮件失败的问题解决的技巧的内容,更多相关内容请关注PHP中文网(www.php.cn)!