邮件发送失败:Mail server connection failed; 501 Syntax: HELO hostname

红薯 发布于 2011/10/13 21:23
阅读 1K+
收藏 0

出现这个问题,是系统利用javamail组件发送邮件,Javamail在提取本地hostname的时候会dig 改hostname,然后以改ip发送邮件。

由于hostname对应的ip地址,linux无法解析(如果是windows则无这个问题,windows利用netbios协议去获得该主机的ip地址)到本机hostname的ip,导致javamail无法调用发送ip。Postfix收到此类邮件将拒绝投递,而产生501错误。

解决办法:

在有利用到javamail的所有主机重写hosts文件或者在dns服务器上设置该主机名的ip就可以解决这个问题。

这个错误的javamail 在发送helo 命令的时候找不到 hostname,直接发送helo命令
所以postfix返回了 501 Syntax: HELO hostname 

javamail 首先会按顺序从下面两个key从session里找 hostname

mail.smtp.localhost 
mail.smtp.localaddress 

找不到的话会使用 InetAddress.getLocalHost() 得到 一个InetAddress 对象再getCanonicalHostName()
在修改hosts之前呢,InetAddress.getLocalHost() 会抛出 
Exception in thread "main" java.net.UnknownHostException: ui41.greenemls.org: ui41.greenemls.org
        at java.net.InetAddress.getLocalHost(InetAddress.java:1353)

这个异常,然后返回null。也就是说不改的话,不单是邮件发不出去,如果有其他地方可能用到InetAddress.getLocalHost()的方法都可能抛出UnknownHostException

另外把javamail升级到1.4.3就可以的原因是在1.4.3的javamail 里,会catch UnknownHostException 并根据当前跟smtp创建socket所使用的ip 
getCanonicalHostName()得到hostname,但是这个得到的hostname

原文出处:http://zhuquancj2008.blog.163.com/blog/static/719113262010621406786/

加载中
返回顶部
顶部