我正在尝试使用以下程序发送邮件,但我收到以下错误消息。
public class SMTPTest {
//private Logger log = Logger.getLogger(this.getClass());
public boolean sendSimpleMail(String to, String subject, String body) {
Properties props = new Properties();
props.put("mail.smtp.user", "amrita_test");
props.put("mail.smtp.password", "aview");
props.put("mail.smtp.host", "192.168.0.25");
props.put("mail.smtp.port", "25");
props.put("mail.smtp.starttls.enable", "true");
props.put("mail.smtp.auth", "true");
// props.put("mail.smtp.debug", "true");
props.put("mail.smtp.debug", "false");
props.put("mail.smtp.socketFactory.port", "425");
props.put("mail.smtp.socketFactory.class",
"javax.net.ssl.SSLSocketFactory");
props.put("mail.smtp.socketFactory.fallback", "false");
try {
Authenticator auth = new SMTPAuthenticator();
Session session = Session.getInstance(props, auth);
// session.setDebug(true);
MimeMessage msg = new MimeMessage(session);
String content = body;
msg.setSubject(subject);
msg.setFrom(new InternetAddress("buddhiedge@gmail.com"));
Address[] addresses = new Address[1];
addresses[0] = new InternetAddress("buddhiedge@gmail.com");
msg.setReplyTo(addresses);
msg.addRecipient(Message.RecipientType.TO, new InternetAddress(to));
msg.setContent(content, "text/html");
Transport.send(msg);
return true;
} catch (Exception mex) {
mex.printStackTrace();
System.out.println("Error in sending mail :: " + mex.getMessage());
return false;
}
}
private class SMTPAuthenticator extends Authenticator {
public PasswordAuthentication getPasswordAuthentication() {
return new PasswordAuthentication("amrita_test",
"aview");
}
}
public static void main(String args[]){
SMTPTest test=new SMTPTest();
test.sendSimpleMail("praveenpkd@gmail.com", "subject", "body");
}
}
错误是: javax.mail.MessagingException:无法连接到SMTP主机:192.168.0.25,port:25;
nested exception is:
java.net.ConnectException: Connection timed out: connect
at com.sun.mail.smtp.SMTPTransport.openServer(SMTPTransport.java:1282)
at com.sun.mail.smtp.SMTPTransport.protocolConnect(SMTPTransport.java:370)
at javax.mail.Service.connect(Service.java:297)
at javax.mail.Service.connect(Service.java:156)
at javax.mail.Service.connect(Service.java:105)
at javax.mail.Transport.send0(Transport.java:168)
at javax.mail.Transport.send(Transport.java:98)
at SMTPTest.sendSimpleMail(SMTPTest.java:45)
at SMTPTest.main(SMTPTest.java:62)
Caused by: java.net.ConnectException: Connection timed out: connect
at java.net.PlainSocketImpl.socketConnect(Native Method)
at java.net.PlainSocketImpl.doConnect(PlainSocketImpl.java:333)
at java.net.PlainSocketImpl.connectToAddress(PlainSocketImpl.java:195)
at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:182)
at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:366)
at java.net.Socket.connect(Socket.java:519)
at com.sun.net.ssl.internal.ssl.SSLSocketImpl.connect(SSLSocketImpl.java:550)
at com.sun.net.ssl.internal.ssl.BaseSSLSocketImpl.connect(BaseSSLSocketImpl.java:141)
at com.sun.mail.util.SocketFetcher.createSocket(SocketFetcher.java:232)
at com.sun.mail.util.SocketFetcher.getSocket(SocketFetcher.java:163)
at com.sun.mail.smtp.SMTPTransport.openServer(SMTPTransport.java:1250)
... 8 more
但是SMTP服务器或连接没有问题。 telnet 192.168.0.25 25 连接好了。 怎么解决这个问题。
答案 0 :(得分:0)
如果是身份验证问题,我相信您会收到其他错误。
您的网络/ SMTP服务器是否支持IP6?如果您的客户端支持IP6,则Java的更高版本默认为IP6,但在IP4上配置了许多SMTP服务器。请参阅此文章Sending email using JSP以获取有关如何配置JVM以强制IP4的说明。这需要在实例化时在JVM上设置。
答案 1 :(得分:0)
请尝试仅从代码中删除以下内容再次发送邮件。
props.put("mail.smtp.socketFactory.port", "425");
props.put("mail.smtp.socketFactory.class",
"javax.net.ssl.SSLSocketFactory");
props.put("mail.smtp.socketFactory.fallback", "false");
通常,例外
仅当java邮件无法连接到指定端口中提到的服务器时才会导致java.net.ConnectException:连接超时
。最可能的原因是java邮件尝试连接到会话属性中指定的425端口。