Страницы

Поиск по вопросам

пятница, 15 марта 2019 г.

Доступ ненадежным приложениям при отправке почты с помощью Gmail

СОбственно говоря,есть задача отправлять письма с помощью 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). Я так думаю,что это делать не желательно(безопасность и все такое), в тоже время решений как обойти эту процедуру я не нашел. Можно ли изменить код так,чтобы проходила аутентификация,доступ ненадежным приложениям был отключен и он не ругался?


Ответ

Сначала включите двухэтапную аутентификацию После этого получите пароль для приложения и используйте его для отправки писем.
Также стоит рассмотреть возможность отправки писем через свой сервер.

Комментариев нет:

Отправить комментарий