Discuz!官方免费开源建站系统

 找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索

Discuz! 邮件发送失败排查思路

[复制链接]
evenzhou 发表于 2012-10-31 16:10:33 | 显示全部楼层 |阅读模式
排查思路

      1,要确保填写的邮件信息是否正确,主要检测邮件服务器格式填写。设置可以参考:( https://discuz.dismall.com/thread-2487756-1-1.html

      2,查看邮件日志文件,data/log目录下 有一个201210_SMTP.php 类似这样的文件,下面举例说明下
    例1:
  1. <?PHP exit;?>        2012-10-17 16:59:59        127.0.0.1        1        /admin.php?action=checktools&operation=mailcheck&frame=no        (smtp.qq.com:25) MAIL FROM -
复制代码
通过失败日志,进入程序 source/function/function_mail.php, sendmail 函数在失败的时候会记录。 如上面的日志中“MAIL FROM”,在sendmail 函数中的代码是。这样就定位到具体的错误地方。
  1. fputs($fp, "MAIL FROM: <".preg_replace("/.*\<(.+?)\>.*/", "\\1", $email_from).">\r\n");
  2.                 $lastmessage = fgets($fp, 512);
  3.                 if(substr($lastmessage, 0, 3) != 250) {
  4.                         fputs($fp, "MAIL FROM: <".preg_replace("/.*\<(.+?)\>.*/", "\\1", $email_from).">\r\n");
  5.                         $lastmessage = fgets($fp, 512);
  6.                         if(substr($lastmessage, 0, 3) != 250) {
  7.                                 runlog('SMTP', "({$_G[setting][mail][server]}:{$_G[setting][mail][port]}) MAIL FROM - $lastmessage", 0);
  8.                                 return false;
  9.                         }
  10.                 }
复制代码
     例2:
  1. Unable to connect to the SMTP server
复制代码
定位到代码sendmail函数的位置
  1. if(!$fp = fsocketopen($_G['setting']['mail']['server'], $_G['setting']['mail']['port'], $errno, $errstr, 30)) {
  2.                         runlog('SMTP', "({$_G[setting][mail][server]}:{$_G[setting][mail][port]}) CONNECT - Unable to connect to the SMTP server", 0);
  3.                         return false;
  4.                 }
复制代码
这的错误可能是服务器禁止访问外部邮件服务器。。这里就不一一例举每种错误的情况 了 。排查思路是通过错误日志定位,然后分析可能的错误原因。  

常见错误情况:
     1. 服务器没有开放25端口
     方法:检测服务器是否开启了25端口方,可以使用telnet命令进行验证,本地安装telnet(安装方式可以到网上搜索相关教程), 运行 --输入cmd --输入telnet   www.xxx.com(或者ip) 25端口 看返回的信息是什么 。 或者咨询空间商是否开放了25端口
   

   ...... 后期将更新整理常见可能情况

  





liqu12511 发表于 2012-10-31 19:18:10 | 显示全部楼层
这个需要在后台设置代理器吗?
回复

使用道具 举报

李渠 发表于 2012-10-31 20:02:20 | 显示全部楼层
官方的大哥们
discuz后台的编辑器代码怎么修改
https://discuz.dismall.com/thread-3132914-1-1.html
回复

使用道具 举报

abcnic18 发表于 2012-11-1 09:40:39 | 显示全部楼层
收藏一下 :)
回复

使用道具 举报

ARCHY` 发表于 2012-11-9 09:02:16 | 显示全部楼层
前排支持下了  我来了
回复

使用道具 举报

etely 发表于 2012-11-10 14:10:48 | 显示全部楼层
好 纯友情支持!!
回复

使用道具 举报

piaoping98 发表于 2012-12-12 09:10:56 | 显示全部楼层
  好帖顶下。
现在我还遇到一种情况,服务器和防火墙设置都正确,部分用户反映QQ邮箱收不到验证邮件,经过仔细查找,在QQ邮箱登录后底部有一项“自助查询”,收件查询里,邮件被当作垃圾邮件拦截,点击“取回”即可。
回复

使用道具 举报

ybs885 发表于 2013-1-20 10:09:27 | 显示全部楼层
谢谢分享。。学习了。。。。。。
回复

使用道具 举报

钟毅001 发表于 2013-1-31 13:22:14 | 显示全部楼层
癫痫论坛网 www.dxlt5.com 来学习了~!
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|Discuz! 官方站 ( 皖ICP备16010102号 )star

GMT+8, 2024-4-25 04:24 , Processed in 0.137677 second(s), 17 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2023, Tencent Cloud.

快速回复 返回顶部 返回列表