一个属性未设置导致发mail不成功的郁闷。

阅读更多
  难得阳光灿烂的周末啊,确被javamail的一个属性未设置,给硬生生的抢夺了。不过总算是找对了问题所在,在这里小计一下,给自己和别人也提醒一下。

  先简介一下我的环境,grails,官方mail插件,运行于jetty(出现异常)和tomcat(很正常),jetty的异常在mac下是
引用
java.net.SocketException: Network is unreachable
at java.net.PlainSocketImpl.socketConnect(Native Method)

而在linux下边却是
引用
java.net.NoRouteToHostException: No route to host

看异常,可以比较明显得出是比较底层的socket问题,一开始,简单的定位为ipv6的问题,但是增加了 java.net.preferIPv4Stacks属性,也没有起作用。这回没法子了,只有根据异常的提示,去查看源代码了(开源实在是太伟大了),发现我配置的逻辑也没有什么不对啊。

  最后,还是打印JavaMailSenderImpl(没错,grails/mail是采用spring的mail机制来实现的)的属性信息,才发现了问题,原来 mail.smtp.socketFactory.port竟然是465,我可没有使用ssl的啊,不知道怎么来的。
  
  我的可以工作的mail的额外property属性如下:
  • mail.smtp.auth=true
  • mail.smtp.socketFactory.class=javax.net.SocketFactory
  • mail.smtp.socketFactory.port=25

结论
建议将mail的几个属性都成对的设置,比如
  • mail.smtp.socketFactory.class/mail.smtp.socketFactory.port
  • ssl同理


你可能感兴趣的:(Grails,Java,.net,Linux,Spring)