使用hotmail帐户使用Java发送电子邮件

时间:2016-01-14 09:18:02

标签: java email hotmail

我正在使用Hotmail帐户发送电子邮件的网络应用程序。这是我的代码:

props.put("mail.transport.protocol", "smtp");
props.put("mail.smtp.host", "smtp.live.com");
props.put("mail.smtp.auth", true);
props.put("mail.smtp.port", "587");
props.put("mail.smtp.user", "mail@hotmail.com");
props.put("mail.smtp.pwd", pass);
props.put("mail.debug", true);
props.put("mail.smtp.starttls.enable", "true");

Session session = Session.getDefaultInstance(props);

session.setDebug(true);

try {
    MimeMessage mimeMessage = new MimeMessage(session);
    mimeMessage.setFrom(new InternetAddress("othermail@otherserver.com"));
    mimeMessage.addRecipient(Message.RecipientType.TO, new InternetAddress("mail@hotmail.com"));
    mimeMessage.setSubject(subject);
    mimeMessage.setContent(message, "text/html; charset=UTF-8");
    mimeMessage.setSentDate(new Date());

    SMTPTransport transport = (SMTPTransport) session.getTransport("smtp");
    transport.connect("smtp.live.com", "mail@hotmail.com", pass);
    transport.sendMessage(mimeMessage, mimeMessage.getAllRecipients());
    transport.close();
} catch (MessagingException e) {
    ret = false;}

当我在本地使用此代码时,一切正常,但当我在托管服务器上部署我的应用程序时,会出现以下跟踪:

DEBUG: setDebug: JavaMail version 1.4.7
DEBUG: getProvider() returning javax.mail.Provider[TRANSPORT,smtp,com.sun.mail.smtp.SMTPTransport,Oracle]
DEBUG SMTP: useEhlo true, useAuth true
DEBUG SMTP: trying to connect to host "smtp.live.com", port 587, isSSL false
220 BLU436-SMTP170.smtp.hotmail.com Microsoft ESMTP MAIL Service, Version: 8.0.9200.16384 ready at  Thu, 14 Jan 2016 00:04:21 -0800 
DEBUG SMTP: connected to host "smtp.live.com", port: 587

EHLO sbi02.namesservers.net
250-BLU436-SMTP170.smtp.hotmail.com Hello [37.187.179.160]
250-TURN
250-SIZE 41943040
250-ETRN
250-PIPELINING
250-DSN
250-ENHANCEDSTATUSCODES
250-8bitmime
250-BINARYMIME
250-CHUNKING
250-VRFY
250-TLS
250-STARTTLS
250 OK
DEBUG SMTP: Found extension "TURN", arg ""
DEBUG SMTP: Found extension "SIZE", arg "41943040"
DEBUG SMTP: Found extension "ETRN", arg ""
DEBUG SMTP: Found extension "PIPELINING", arg ""
DEBUG SMTP: Found extension "DSN", arg ""
DEBUG SMTP: Found extension "ENHANCEDSTATUSCODES", arg ""
DEBUG SMTP: Found extension "8bitmime", arg ""
DEBUG SMTP: Found extension "BINARYMIME", arg ""
DEBUG SMTP: Found extension "CHUNKING", arg ""
DEBUG SMTP: Found extension "VRFY", arg ""
DEBUG SMTP: Found extension "TLS", arg ""
DEBUG SMTP: Found extension "STARTTLS", arg ""
DEBUG SMTP: Found extension "OK", arg ""
STARTTLS
220 2.0.0 SMTP server ready
EHLO sbi02.namesservers.net
250-BLU436-SMTP170.smtp.hotmail.com Hello [37.187.179.160]
250-TURN
250-SIZE 41943040
250-ETRN
250-PIPELINING
250-DSN
250-ENHANCEDSTATUSCODES
250-8bitmime
250-BINARYMIME
250-CHUNKING
250-VRFY
250-AUTH LOGIN PLAIN XOAUTH2
250 OK
DEBUG SMTP: Found extension "TURN", arg ""
DEBUG SMTP: Found extension "SIZE", arg "41943040"
DEBUG SMTP: Found extension "ETRN", arg ""
DEBUG SMTP: Found extension "PIPELINING", arg ""
DEBUG SMTP: Found extension "DSN", arg ""
DEBUG SMTP: Found extension "ENHANCEDSTATUSCODES", arg ""
DEBUG SMTP: Found extension "8bitmime", arg ""
DEBUG SMTP: Found extension "BINARYMIME", arg ""
DEBUG SMTP: Found extension "CHUNKING", arg ""
DEBUG SMTP: Found extension "VRFY", arg ""
DEBUG SMTP: Found extension "AUTH", arg "LOGIN PLAIN XOAUTH2"
DEBUG SMTP: Found extension "OK", arg ""
DEBUG SMTP: Attempt to authenticate using mechanisms: LOGIN PLAIN DIGEST-MD5 NTLM 
DEBUG SMTP: AUTH LOGIN command trace suppressed
DEBUG SMTP: AUTH LOGIN failed
535 5.0.0 Authentication Failed

我确信帐户凭据正确但身份验证失败。 此外,我必须说,当我尝试这样做时,我收到一封微软的电子邮件说,有一个欺诈性的尝试开始会话,但当我在本地执行代码时,我没有收到这封电子邮件。 我看了一下页面帐户信息和securty& Privacity部分,看到我最近的活动出现挑战安全性关于此尝试发送电子邮件。在此信息中,设备和平台是未知的,而ip是我的托管。 有什么方法可以做到吗?

1 个答案:

答案 0 :(得分:0)

我只找到了解决问题的方法。我已在帐户中启用了两步验证。启用此选项后,hotmail会为您提供创建应用程序密码的选项。此密码是我在应用程序中使用的密码,而不是hotmail帐户的真实密码。此解决方案也适用于Gmail帐户。