Chinaunix首页 | 论坛 | 博客
  • 博客访问: 4177648
  • 博文数量: 291
  • 博客积分: 8003
  • 博客等级: 大校
  • 技术积分: 4275
  • 用 户 组: 普通用户
  • 注册时间: 2010-10-30 18:28
文章分类

全部博文(291)

文章存档

2017年(1)

2013年(47)

2012年(115)

2011年(121)

2010年(7)

分类: Java

2012-10-11 13:10:07

今天出现了一个奇怪的问题,产品机A上有一个邮件服务器,产品机A和产品机B的java程序都是用A上的邮件服务器发邮件,但是测试发现,产品机B上的java程序发送邮件正常,而产品机A上的java程序发送不出去,更奇怪的是A上的php程序也能够发送邮件!
查到tomcat日志如下:

点击(此处)折叠或打开

  1. javax.mail.MessagingException: 501 Domain address required: HELO
  2. at com.sun.mail.smtp.SMTPTransport.issueCommand(SMTPTransport.java:1481)
  3. at com.sun.mail.smtp.SMTPTransport.helo(SMTPTransport.java:917)
  4. at com.sun.mail.smtp.SMTPTransport.protocolConnect(SMTPTransport.java:417)
  5. at javax.mail.Service.connect(Service.java:288)
  6. at javax.mail.Service.connect(Service.java:169)
  7. at

比较了A和B的java程序,完全一模一样。
查了半天百度,google都没有结果
最后找到了一个说法是因为hostname引起的,于是我用hostname命令查到了A的hostname是PRODA,而ping 它却是没有结果,看了一下/etc/hosts文件中,发现“127.0.0.1 PROD-A”,写多了一杠

改好之后再测试就能够发送了
我估计虽然传的是server的域名,但是mail.jar会先获取本机的hostname进行解析,解析不到就不发送HELO命令了,但是Server需要检测这个命令。而php的发邮件程序实现时不判断hostname就直接发送HELO命令,因此能够发送成功
阅读(5931) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~