[PHP] PHPMailer发信失败,用这种方式找原因
当有个功能要发送通知邮件时 , 大家都会去用PHPMailer来调用第三方的smtp发信 , 经常遇到莫名其妙的错误 ,不知道是什么原因 .
今天我也遇到了这种问题 , 在发信时一直都是false , 找了半天
这个类库最终还是拼接的smtp协议 , 与我们自己手动telnet然后 auth login ,mail from 等是一样的 , 但是我们不知道他最终拼成的smtp协议究竟是什么样的 , 所以不知道原因
需要使用strace命令来查看类库究竟发送和接收到了什么 ?
可以这样使用 strace -e sendto,recvfrom -s 1024000 php testmail.php
-e是过滤参数的意思 , 只打印 sendto和recvfrom的信息 , -s是数据的长度 ,写长一点 ,得到以下结果
sendto(3, "EHLO localhost.localdomain\r\n", 28, MSG_DONTWAIT, NULL, 0) = 28
recvfrom(3, "220 smtp-30-235.smtpsmail.email.yf.sinanode.com ESMTP\r\n", 8192, MSG_DONTWAIT, NULL, NULL) = 55
sendto(3, "HELO localhost.localdomain\r\n", 28, MSG_DONTWAIT, NULL, 0) = 28
recvfrom(3, "250-smtp-30-235.smtpsmail.email.yf.sinanode.com\r\n250-AUTH LOGIN PLAIN\r\n250-AUTH=LOGIN PLAIN\r\n250-STARTTLS\r\n250 8BITMIME\r\n", 8192, MSG_DONTWAIT, NULL, NULL) = 121
sendto(3, "AUTH LOGIN\r\n", 12, MSG_DONTWAIT, NULL, 0) = 12
recvfrom(3, "250 smtp-30-235.smtpsmail.email.yf.sinanode.com\r\n", 8192, MSG_DONTWAIT, NULL, NULL) = 49
sendto(3, "bm90aWNlaQHaNpbmEubmV0\r\n", 22, MSG_DONTWAIT, NULL, 0) = 22
recvfrom(3, "334 VXNlcm5hbWU6\r\n", 8192, MSG_DONTWAIT, NULL, NULL) = 18
sendto(3, "dG9uZ3paoaV8yMDMa5NDRfMQ==\r\n", 26, MSG_DONTWAIT, NULL, 0) = 26
recvfrom(3, "334 UGFzc3dvcamQ6\r\n", 8192, MSG_DONTWAIT, NULL, NULL) = 18
sendto(3, "MAIL FROM:<notice@sina.net>\r\n", 29, MSG_DONTWAIT, NULL, 0) = 29
recvfrom(3, "235 OK Authenticated\r\n", 8192, MSG_DONTWAIT, NULL, NULL) = 22
The following From address failed: xxxx@sina.net
看到这么一段信息 , 里面清楚的标出了sendto发出去的数据 和recvfrom收回来的数据 , 经过对比class.smtp.php 代码
最终发现是在新浪企邮的smtp返回信息 与其他免费邮箱的smtp信息 多几行 , 而类库还是按照他自己的逻辑只读取了一行记录 , 因此很多地方就对不上了 , 错位了
把smtp代码里 读取返回数据的地方对应好 , 他切分前三个数字作为返回码进行判断 ,有些也判断的不对 , 多对应一下改一改源码
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
2018-03-10 [日常] MySQL的哈希索引和原理研究测试
2016-03-10 [android] 常用数据适配器ArrayAdapter
2016-03-10 [android] 采用layoutInflater打气筒创建一个view对象