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

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

先简介一下我的环境,grails,官方mail插件,运行于jetty(出现异常)和tomcat(很正常),jetty的异常在mac下是
[quote]java.net.SocketException: Network is unreachable
at java.net.PlainSocketImpl.socketConnect(Native Method)[/quote]
而在linux下边却是
[quote]java.net.NoRouteToHostException: No route to host[/quote]
看异常,可以比较明显得出是比较底层的socket问题,一开始,简单的定位为ipv6的问题,但是增加了[b]java.net.preferIPv4Stack[/b]s属性,也没有起作用。这回没法子了,只有根据异常的提示,去查看源代码了(开源实在是太伟大了),发现我配置的逻辑也没有什么不对啊。

最后,还是打印JavaMailSenderImpl(没错,grails/mail是采用spring的mail机制来实现的)的属性信息,才发现了问题,原来[b]mail.smtp.socketFactory.port[/b]竟然是465,我可没有使用ssl的啊,不知道怎么来的。

我的可以工作的mail的额外property属性如下:
[list]
[*]mail.smtp.auth=true
[*]mail.smtp.socketFactory.class=javax.net.SocketFactory
[*]mail.smtp.socketFactory.port=25
[/list]
[b][size=large]结论[/size][/b]
建议将mail的几个属性都成对的设置,比如
[list]
[*]mail.smtp.socketFactory.class/mail.smtp.socketFactory.port
[*] ssl同理
[/list]
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章