您好,登錄后才能下訂單哦!
這篇文章主要介紹Linux服務(wù)器下PHPMailer發(fā)送郵件失敗怎么辦,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!
需求
更換服務(wù)器之后,我發(fā)現(xiàn)我的發(fā)送郵件功能失效了!原來的服務(wù)器是可以的,一定是哪里出問題了,決定來排查一下。我是用的PHPMailer,SMTP方式發(fā)送郵件的。
排查過程
這種方式首先PHP要開啟sockets拓展,查了一下phpinfo頁面,是開啟的:
看了一下openssl也是開啟(因?yàn)槟昧藂q郵箱來測),所以沒問題:
那就再看一下allow_url_fopen,開啟的,沒問題:
是不是禁用了函數(shù)?沒有禁用,沒問題:
那配置上就沒有問題了,我就想,是不是端口被占用了?
運(yùn)行一下:netstat -tnlp
第一條就是這玩意:
25端口被占用,被一個叫master的玩意占了,好家伙,看看是什么東西,運(yùn)行ps -f -p 1818
看一下結(jié)果,1818為當(dāng)前這個程序的進(jìn)程號PID,可以看到是:
是postfix這個東西在運(yùn)行,可能搭建環(huán)境的時(shí)候不小心給裝了。
postfix是個什么東西?
postfix是一款運(yùn)行在Linux環(huán)境下免費(fèi)的郵件服務(wù)器,或者稱為MTA(Mail Transfer Agent),其它類似的有Sendmail、Qmail、exim及Zmailer 等。所以Postfix就是一個搭郵件服務(wù)器的。那這玩意肯定是沖突了,我們要通過25端口請求外部的郵件服務(wù)器,而本地用25端口運(yùn)行了一個郵件服務(wù)器,這個是不行的估計(jì).
嘗試解決問題
我們嘗試一下用我們這個郵件服務(wù)器去發(fā)郵件,而不是用外部服務(wù)器(比如之前用阿里云企業(yè)郵),放了一小段測試代碼到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 = '鍋?zhàn)?#39;; $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 "郵件發(fā)送失?。?quot;.$e->errorMessage(); }
通過25端口的本地服務(wù)器發(fā)送郵件,運(yùn)行這個頁面,發(fā)現(xiàn)不行,報(bào)錯不能夠驗(yàn)證,說明這其中還有一些配置要弄,暫時(shí)行不通,不往下深究本地服務(wù)器發(fā)送了,我們嘗試一下?lián)Q回:
$mail->Host = ‘smtp.mxhichina.com'; //阿里云的郵箱smtp地址
試一下,還是不行:
沒辦法連接到SMTP。那我們把25端口的postfix服務(wù)器殺掉, 執(zhí)行kill 1818(當(dāng)前postfix的PID),再執(zhí)行一次,還是同樣錯誤,無法連接上。這就奇了怪了,25端口沒有程序運(yùn)行了,還不行。
可能的原因
查到有可能是因?yàn)閕pv6的原因,phpMailer在進(jìn)行smtp服務(wù)器DNS解析時(shí),得到了IP v6地址,然后與IP v6解析到的地址進(jìn)行連接,導(dǎo)致連接失敗。
我試一下:
ip -6 addr show
沒東西,那又不是這個問題。
那是什么原因呢?
解決問題
既然25端口不可用,于是我想,是否可以嘗試一下其它端口,用465端口試試。
465端口(SMTPS):465端口是為SMTPS(SMTP-over-SSL)協(xié)議服務(wù)開放的,這是SMTP協(xié)議基于SSL安全協(xié)議之上的一種變種協(xié)議,它繼承了SSL安全協(xié)議的非對稱加密的高度安全可靠性,可防止郵件泄露。SMTPS和SMTP協(xié)議一樣,也是用來發(fā)送郵件的,只是更安全些,防止郵件被黑客截取泄露,還可實(shí)現(xiàn)郵件發(fā)送者抗抵賴功能。防止發(fā)送者發(fā)送之后刪除已發(fā)郵件,拒不承認(rèn)發(fā)送過這樣一份郵件。
465端口似乎看起來還更好,直接就開始嘗試了,進(jìn)行以下嘗試,以下為命令:
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
查看需要打開的端口是否生效?
似乎可行,現(xiàn)在嘗試一下,用SMTP的465SSL連接方式來發(fā)送郵件,稍微改了一下測試代碼:
<?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 = '鍋?zhàn)?#39;; $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 "郵件發(fā)送失?。?quot;.$e->errorMessage(); //測試的時(shí)候可以去掉此行的注釋 }
執(zhí)行,成功!右下角彈出了QQ郵件的提醒。
總結(jié)
PHPMailer通過465端口進(jìn)行更安全的SMTPS協(xié)議發(fā)送郵件
可以修改:
$mail->Port = 465;
為:
$mail->SMTPSecure = 'ssl'; $mail->Port = 465;
即可。
以上是“Linux服務(wù)器下PHPMailer發(fā)送郵件失敗怎么辦”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注億速云行業(yè)資訊頻道!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。