СОбственно говоря,есть задача отправлять письма с помощью java. Покопавшись в сети, прописал такой код:
public class MailSender {
private final String username = "адрес ящика, с которого отправляем письмо";
private final String password = "пароль к почтовому ящику";
public void MailSending(Message DataMessage){
Properties props = new Properties();
props.put("mail.smtp.starttls.enable", "true");
props.put("mail.smtp.auth", "true");
props.put("mail.smtp.host", "smtp.gmail.com");
props.put("mail.smtp.port", "587");
props.put("mail.smtp.ssl.trust", "smtp.gmail.com");
Session session = Session.getInstance(props,
new javax.mail.Authenticator() {
protected PasswordAuthentication getPasswordAuthentication() {
return new PasswordAuthentication(username, password);
}
});
try {
MimeMessage message = new MimeMessage(session);
message.setFrom(new InternetAddress(DataMessage.getFrom()));
message.addRecipient(MimeMessage.RecipientType.TO, new InternetAddress(DataMessage.getTo()));
message.setSubject(DataMessage.getSubject());
message.setText(DataMessage.getBody());
Transport.send(message); System.out.println("Email Sent successfully....");
} catch (MessagingException mex){ mex.printStackTrace(); }
}
Это дело работает и письма шлет,НО только в том случае, если я в настройках ящика включаю "доступ к ненадежным приложениям"(в противном случае кидает в меня javax.mail.AuthenticationFailedException). Я так думаю,что это делать не желательно(безопасность и все такое), в тоже время решений как обойти эту процедуру я не нашел. Можно ли изменить код так,чтобы проходила аутентификация,доступ ненадежным приложениям был отключен и он не ругался?
Ответ
Сначала включите двухэтапную аутентификацию
После этого получите пароль для приложения и используйте его для отправки писем.
Также стоит рассмотреть возможность отправки писем через свой сервер.
Комментариев нет:
Отправить комментарий