SMTP エラー: SMTP ホストに接続できませんでした。メッセージを送信できませんでした。
メーラー エラー: SMTP エラー: SMTP ホストに接続できませんでした。
PHPMailer を CentOS で動作させる方法が見つからないようです。メールは Windows では XAMPP で問題なく動作しますが、Linux では常にこのエラーが発生します。
SMTP サーバーは、ポート 25 でリッスンする Lotus Domino です。CentOS マシンにはファイアウォールがまったくなく、奇妙なことに、mail() でさえ機能しません。何も返しません (Windows では 1 が返されます)。CentOS サーバー経由で telnet 経由で電子メールを送信すると、問題なく動作するので、ネットワークの問題ではないと思います。PHPに関連しているに違いありませんが、方法がわかりません。
<?php
require("class.phpmailer.php");
$mail = new PHPMailer();
$mail->IsSMTP();
$mail->Host = "192.168.x.x";
$mail->SMTPAuth = false;
$mail->From = "xxx@xxx.it";
$mail->FromName = "XXX";
$mail->AddAddress("xxx@xxx.it");
$mail->IsHTML(true);
$mail->Subject = "Test";
$mail->Body = "Test";
if(!$mail->Send())
{
echo "Message could not be sent. <p>";
echo "Mailer Error: " . $mail->ErrorInfo;
exit;
}
echo "Message has been sent";
?>
上記のコードを明確にするために、XAMPP (Windows) で動作します。
PHPMailer でエラーをデバッグしたところ、ここでエラーが発生しました (class.smtp.php メソッド Connect()):
$this->smtp_conn = @fsockopen($host, // the host of the server
$port, // the port to use
$errno, // error number if any
$errstr, // error message if any
$tval); // give up after ? secs
// verify we connected properly
if(empty($this->smtp_conn)) {
$this->error = array("error" => "Failed to connect to server",
"errno" => $errno,
"errstr" => $errstr);
if($this->do_debug >= 1) {
echo "SMTP -> ERROR: " . $this->error["error"] . ": $errstr ($errno)" . $this->CRLF . '<br />';
}
return false;
}
ソケットを開けないようです...
更新: $mail->SMTPDebug = 2; の使用。アルバロが提案したように、次の出力が生成されました。
SMTP -> エラー: サーバーへの接続に失敗しました: 権限が拒否されました (13)