zoukankan      html  css  js  c++  java
  • [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 ", 28, MSG_DONTWAIT, NULL, 0) = 28
    recvfrom(3, "220 smtp-30-235.smtpsmail.email.yf.sinanode.com ESMTP ", 8192, MSG_DONTWAIT, NULL, NULL) = 55
    sendto(3, "HELO localhost.localdomain ", 28, MSG_DONTWAIT, NULL, 0) = 28
    recvfrom(3, "250-smtp-30-235.smtpsmail.email.yf.sinanode.com 250-AUTH LOGIN PLAIN 250-AUTH=LOGIN PLAIN 250-STARTTLS 250 8BITMIME ", 8192, MSG_DONTWAIT, NULL, NULL) = 121
    sendto(3, "AUTH LOGIN ", 12, MSG_DONTWAIT, NULL, 0) = 12
    recvfrom(3, "250 smtp-30-235.smtpsmail.email.yf.sinanode.com ", 8192, MSG_DONTWAIT, NULL, NULL) = 49
    sendto(3, "bm90aWNlaQHaNpbmEubmV0 ", 22, MSG_DONTWAIT, NULL, 0) = 22
    recvfrom(3, "334 VXNlcm5hbWU6 ", 8192, MSG_DONTWAIT, NULL, NULL) = 18
    sendto(3, "dG9uZ3paoaV8yMDMa5NDRfMQ== ", 26, MSG_DONTWAIT, NULL, 0) = 26
    recvfrom(3, "334 UGFzc3dvcamQ6 ", 8192, MSG_DONTWAIT, NULL, NULL) = 18
    sendto(3, "MAIL FROM:<notice@sina.net> ", 29, MSG_DONTWAIT, NULL, 0) = 29
    recvfrom(3, "235 OK Authenticated ", 8192, MSG_DONTWAIT, NULL, NULL) = 22
    The following From address failed: xxxx@sina.net

    看到这么一段信息 , 里面清楚的标出了sendto发出去的数据 和recvfrom收回来的数据 , 经过对比class.smtp.php 代码 

    最终发现是在新浪企邮的smtp返回信息 与其他免费邮箱的smtp信息 多几行 , 而类库还是按照他自己的逻辑只读取了一行记录 , 因此很多地方就对不上了 , 错位了 

    把smtp代码里 读取返回数据的地方对应好 , 他切分前三个数字作为返回码进行判断 ,有些也判断的不对 , 多对应一下改一改源码

  • 相关阅读:
    webview 缓存
    winform 托盘
    winform自动保存属性变更
    序列化条件
    System.Web.HttpUtility VS System.Net.WebUtility
    javascript模拟sleep
    C#实现把科学计数法(E)转化为正常数字值 (转)
    appium远程连手机调控
    adb通过wifi连接android设备
    在项目中接口测试时怎么做的?
  • 原文地址:https://www.cnblogs.com/taoshihan/p/12457141.html
Copyright © 2011-2022 走看看