DEBUG: setDebug: JavaMail version 1.5.2
DEBUG: getProvider() returning javax.mail.Provider[TRANSPORT,smtp,com.sun.mail.smtp.SMTPTransport,Oracle]
DEBUG SMTP: useEhlo true, useAuth true
DEBUG SMTP: trying to connect to host "xxx", port 25, isSSL false
Exception in thread "main" com.sun.mail.util.MailConnectException: Couldn't connect to host, port: xxx, 25; timeout -1;
nested exception is:
java.net.SocketException: Network is unreachable: connect
at com.sun.mail.smtp.SMTPTransport.openServer(SMTPTransport.java:2053)
at com.sun.mail.smtp.SMTPTransport.protocolConnect(SMTPTransport.java:697)
at javax.mail.Service.connect(Service.java:364)
at com.navinfo.wolverine.test.mail.MailApi.main(MailApi.java:74)
Caused by: java.net.SocketException: Network is unreachable: connect
at java.net.DualStackPlainSocketImpl.connect0(Native Method)
at java.net.DualStackPlainSocketImpl.socketConnect(DualStackPlainSocketImpl.java:79)
at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:339)
at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:200)
at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:182)
at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:172)
at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392)
at java.net.Socket.connect(Socket.java:579)
at com.sun.mail.util.WriteTimeoutSocket.connect(WriteTimeoutSocket.java:107)
at com.sun.mail.util.SocketFetcher.createSocket(SocketFetcher.java:312)
at com.sun.mail.util.SocketFetcher.getSocket(SocketFetcher.java:236)
at com.sun.mail.smtp.SMTPTransport.openServer(SMTPTransport.java:2019)
/********************************* 一条华丽的分割线 *************************************/
经过各种百度、各种谷歌,各种尝试 未果,奇怪的是以前可以正常运行的代码,居然也报这个错 ~~~
无奈换个系统试试吧,将项目移到 Linux 上进行测试,我 KAO ,居然没问题了。
Eclipse 、JDK 版本都是一样的,唯独平台不一样,难道是JDK的问题。带着这个疑问,在Windows上将现在用的JDK1.7更换为JDK1.6。尼玛,太阳出来了,邮件发出去了。
总结:问题出在 JDK1.7 上。
2中解决办法:
一:如果是main方法:
/*
* jdk7+ 在安装有 IPv6 和 IPv4 的计算机上,会使用一种 IPv6 模拟的 IPv4, 而 windows
* 防火墙会把这种模拟的 IPv4 数据挡住。 所以要配置系统参数优先用IP4
*/
System.setProperty("java.net.preferIPv4Stack", "true");
----------——-----------------------------————--------------------
二:直接给jdk 添加参数:-Djava.net.preferIPv4Stack=true