12

我有一个使用 javax.mail 发送 SMTP 消息的 Java 程序。这个程序在 Linux 机器上运行良好,我想事先强调一下。当我在我的 Windows 7 x64 机器上尝试相同的代码时,我收到此错误:

send failed, exception: javax.mail.MessagingException: Could not connect to SMTP host:     smtp.west.cox.net, port: 25;
nested exception is:  java.net.SocketException: Network is unreachable: connect

这是代码:

Session session = Session.getInstance(props, null);
MimeMessage msg = new MimeMessage(session);
msg.setFrom();
msg.setRecipients(Message.RecipientType.TO, props.getProperty("mail.to", "me@mine.com"));
msg.setSubject(mySubject);
msg.setSentDate(new Date());
msg.setContent(sBuf.toString(), "text/html");
Transport.send(msg);

该程序几乎对所有内容都使用默认值。它在同一网络上的另一个盒子上工作正常。它使用的设置与我用于常规邮件客户端的设置相同,效果很好。这个 Windows 盒子上有一些东西阻止了 SMTP,但仅适用于 Java。

我安装了 Symantec (Norton) 360。关闭它没有任何区别,但重新启动到安全模式(几乎禁用所有东西)允许程序正常工作并发送邮件。

所以,回顾一下:

  1. 程序代码有效。
  2. 设置正确。
  3. SMTP 适用于 Windows Mail,仅在此 Windows 机器上被 Java 阻止。

在我再花一天时间拆开东西并卸载/重新安装之前,我想知道是否有人对解决此问题有任何建议?

4

6 回答 6

51

问题是由于 Java 的 IPv4/IPv6 偏好。Java 尝试默认使用 IPv6 (?) 而我的 ISP 不支持 IPV6。但是,默认情况下,它在我的 Windows 7 机器上启用。

如果您遇到类似的行为,您可以通过转到“控制面板/网络和 Internet/网络连接”,右键单击您的 Internet 连接,然后从上下文菜单中选择“状态”来验证这一点。状态对话框将显示与此类似的两行:

IPv4 Connectivity:  Internet
IPv6 Connectivity:  No Internet access

这是问题的根源——Java 更喜欢 IPv6,它不能用来连接到 Internet。

要解决此问题,请执行以下其中一项(或两项)操作:

  1. 在 Windows 7 机器上禁用 IPv6。
  2. 使用此命令行选项启动您的 java 程序:

    -Djava.net.preferIPv4Stack=true
    

执行其中任何一项都可以解决问题。

于 2012-12-28T16:14:35.240 回答
12

在从 java 1.6 升级到 java 1.7 期间,我遇到了同样的问题。出现问题是因为 java 1.7 默认使用 IPv6。要解决此问题,您需要添加 Java 选项,如下例所示。

只需在 Windows cmd 上运行此命令:

setx _JAVA_OPTIONS -Djava.net.preferIPv4Stack=true
于 2013-08-09T05:26:16.600 回答
3

Synantec EP 12.1 RU5解决了您的问题。

Symantec Endpoint Protection 阻止 Java 邮件客户端发送的电子邮件

修复 ID:3399185

症状:Symantec Endpoint Protection 的 Internet 电子邮件自动防护功能会阻止 Java 邮件客户端发送的 SMTP 电子邮件。

解决方案:更新了 Internet 电子邮件自动防护驱动程序以允许处理 IPv4 映射的 IPv6 地址。

于 2014-12-01T12:23:13.987 回答
2

我也面临同样的问题,基本上是 Java 7 问题,只需传入 JVM 参数“-Djava.net.preferIPv4Stack=true”,我就摆脱了问题。

于 2013-10-02T16:40:35.617 回答
1

尽管此问题已解决:指出某些 Windows 防火墙基于可执行文件名称(而不是纯粹的端口号本身)阻止/允许访问端口可能仍然有用 - 因此您最终可以使用一个程序(例如 Outlook ) 被允许,而另一个(比如 Java)被阻止。

于 2015-02-26T21:39:38.837 回答
-1

我有类似的问题,但奇怪的是,一旦我安装了 jdk 1.7,jdk 1.6 一切正常,我得到了异常。我想知道这可能是什么原因!

添加 IPV4 参数后,它工作正常。非常感谢。

于 2014-06-06T20:06:28.837 回答