javax.mail.MessagingException: 501

Mail server connection failed; nested exception is javax.mail.MessagingException: 501 Syntax: HELO

出现这个问题,是系统利用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里找 hostnamemail.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 

你可能感兴趣的:(java)