В моем приложении я подключаюсь к серверу для аутентификации пользователей. Это код:
try {
Properties prop = new Properties();
prop.put("mail.smtp.starttls.enable","true");
prop.put("mail.smtp.auth", "true");
prop.put("mail.smtp.connectiontimeout", 1000);
Session session = Session.getInstance(prop, null);
Transport transport = session.getTransport("smtp");
transport.connect("mion.elka.pw.edu.pl", 587, registerLog, registerPass);
transport.close();
return true;
} catch (NoSuchProviderException ex) {
Logger.getLogger(RegisterController.class.getName()).log(Level.SEVERE, null, ex);
return false;
} catch(AuthenticationFailedException ex) {
Logger.getLogger(RegisterController.class.getName()).log(Level.SEVERE, null, ex);
return false;
} catch (MessagingException ex) {
Logger.getLogger(RegisterController.class.getName()).log(Level.SEVERE, null, ex);
return false;
}
Я установил время ожидания соединения до 1000 мс = 1 с, но он игнорирует. Когда я отлаживаю и устанавливаю неправильное имя пользователя и пароль, я поймаю
javax.mail.MessagingException: java.net.SocketTimeoutException: Read timed out
не после 1000 мс, но после 5000 * 60 мс = 5 мин
Что не так? Как я могу сократить время ожидания?