排查过程
这种方式首先PHP要开启sockets拓展,查了一下phpinfo页面,是开启的:
看了一下openssl也是开启(因为拿了qq邮箱来测),所以没问题:
那就再看一下allow_url_fopen,开启的,没问题:
是不是禁用了函数?没有禁用,没问题:
那配置上就没有问题了,我就想,是不是端口被占用了?
如果有问题 就这样
你可以打开php.ini。有两个地方可能禁用此函数:
1、 allow_url_fopen = On选项是否为ON,为OFF时函数将被禁用
2、查看 disable_functions = ..........后有没有 fsockopen。如果有去掉
运行一下: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端口运行了一个邮件服务器,这个是不行的估计.
建议 kill -9 杀掉这个进程试一试
如果不行就继续看
在linux上看是否是防火墙/selinx的问题
运行这两条命令 试一试 首先你得开启selinux (不知道selinx的自行百度)
setsebool -P httpd_can_sendmail on
setsebool -P httpd_can_network_connect on
如果还不行的话 - - 那就继续吧
这个时候查看 自己的 邮箱端口 是否被什么占用
telnet 25
如果还不行的话我建议你先看下大小写问题 !(因为很重要)
1、@fsockopen 改为@pfsockopen
2、smtp 改为SMTP
3、打开防火墙 从新打开一个465端口 (实在不行换个端口吧 一样的)
解决问题
既然25端口不可用,于是我想,是否可以尝试一下其它端口,用465端口试试。
465端口(SMTPS):465端口是为SMTPS(SMTP-over-SSL)协议服务开放的,这是SMTP协议基于SSL安全协议之上的一种变种协议,它继承了SSL安全协议的非对称加密的高度安全可靠性,可防止邮件泄露。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连接方式来发送邮件,稍微改了一下测试代码:
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
|
<?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协议发送邮件
可以修改:
|
1
|
$mail
->Port = 465;
|
为:
|
1
2
|
$mail
->SMTPSecure =
'ssl'
;
$mail
->Port = 465;
|

本文介绍了在Linux服务器上使用PHPMailer发送邮件遇到的问题及解决方案。当PHPMailer在Windows上工作正常,但在Linux上失败时,排查过程包括检查PHP的sockets拓展、openssl、allow_url_fopen设置、函数禁用情况以及端口占用。发现25端口被postfix邮件服务器占用,通过kill进程、调整SELinux设置和尝试更换端口如465(SMTPS)来解决问题。最终,通过465端口的SMTPS协议成功发送邮件。







1402

被折叠的 条评论
为什么被折叠?



