9

问题:

我正在尝试使用 JavaMail 从 EC2 Ubuntu 12.04 服务器发送电子邮件,但它不起作用。


背景:

我打算将自动生成的邮件从 Tomcat 服务器发送给几个团队成员。我使用 JavaMail 1.4.7 来完成这项任务,并且我已经成功地在本地安装的 Tomcat(在个人笔记本电脑上)上尝试了它。

下一步是我将此模块放在 EC2 服务器上,但它开始失败并出现以下错误:


错误:

调试 SMTP:AUTH LOGIN 失败 javax.mail.AuthenticationFailedException:535-5.7.1 用户名和密码不被接受。如需了解详情,请访问 535 5.7.1 http://support.google.com/mail/bin/answer.py?answer=14257 j13sm1603739pat.17 - gsmtp

at com.sun.mail.smtp.SMTPTransport$Authenticator.authenticate(SMTPTransport.java:826)
at com.sun.mail.smtp.SMTPTransport.authenticate(SMTPTransport.java:761)
at com.sun.mail.smtp.SMTPTransport.protocolConnect(SMTPTransport.java:685)
at javax.mail.Service.connect(Service.java:295)
at javax.mail.Service.connect(Service.java:176)

代码片段:

Security.addProvider(new com.sun.net.ssl.internal.ssl.Provider());
Properties props = new Properties();
props.put("mail.smtps.host","smtp.gmail.com");
props.put("mail.transport.protocol", "smtp");
props.put("mail.smtps.auth", "true");
props.put("mail.smtp.debug", "true");
props.put("mail.smtp.port", 465);
props.put("mail.smtp.socketFactory.port", 465);
props.put("mail.smtp.socketFactory.class", "javax.net.ssl.SSLSocketFactory");
props.put("mail.smtp.socketFactory.fallback", "false");
props.put("mail.smtp.ssl.enable", true);

Session session = Session.getDefaultInstance(props);
session.setDebug(debug);

Message msg = new MimeMessage(session);
InternetAddress addressFrom = new InternetAddress("fromId@gmail.com");
msg.setFrom(addressFrom);

InternetAddress[] addressTo = new InternetAddress[recipients.length];
for (int i = 0; i < recipients.length; i++) {
addressTo[i] = new InternetAddress(recipients[i]);
}
msg.setRecipients(Message.RecipientType.TO, addressTo);
msg.setSubject("test subject");
msg.setContent("test message", "text/plain");
Transport tp = session.getTransport("smtp");
tp.connect(SMTP_HOST_NAME, "dummyId@gmail.com", "dummypassword");
tp.sendMessage(msg, addressTo);
tp.close();

附加信息:

  1. 我已经为 EC2 实例上的所有端口添加了权限。此外,我还为端口 465(SMTPS) 和 25(SMTP) 添加了显式权限。
  2. 我已经交叉检查了代码中提供的用户名和密码的正确性。
4

1 回答 1

7

过去,从 EC2 内的服务器发送的垃圾邮件一直是亚马逊和邮件服务提供商的主要问题。最初,亚马逊故意没有足够的 DNS 信息来通过常见电子邮件服务的反垃圾邮件检查(缺少 DNS 反向查找 PTR 记录),然后亚马逊引入了低邮件配额,遵循批准流程以完全访问 EC2 或 SES 邮件(提供特定的技术设置以完全启用外发电子邮件)。

这是一个描述一些历史的链接: http: //shlomoswidler.com/2009/07/sending-email-from-ec2.html

虽然您收到的错误是 Gmail 服务器上的身份验证失败,但可能是(可能是)因为 Gmail 将您的发件人 IP 地址识别为潜在的垃圾邮件发送者,因为您没有正确设置 Amazon 反向 DNS 查找属性。

  1. 设置 Amazon Reverse DNS 查找详细信息,以便 Gmail 不会将您的邮件检测为垃圾邮件。看来这只能通过提交申请表以取消电子邮件发送配额来完成。来自 Amazon EC2 IP 信息常见问题:

    问:我可以为我的弹性 IP 地址配置反向 DNS 记录吗?

    是的,您可以配置您的弹性 IP 地址的反向 DNS 记录(提交请求删除电子邮件发送限制表单)。请注意,在我们创建反向 DNS 记录之前,必须存在指向该弹性 IP 地址的相应正向 DNS 记录。

    以下是电子邮件配额用尽时亚马逊发送的电子邮件示例 - 再次说明 DNS PTR 配置的请求和批准:http: //www.practicalclouds.com/content/guide/sending-email-ec2-instances

  2. 请严格按照 Gmail 错误消息中包含的链接中的所有说明进行操作:http: //support.google.com/mail/bin/answer.py ?answer=14257 。如果 Gmail 认为您的帐户正在从您的 IP 地址发送垃圾邮件,这将重置您的 Gmail 帐户状态。

  3. 或者,您可以通过 Amazon SES 发送邮件,同样需要请求、批准和 Amazon 提供的适当配置。这允许通过 发送邮件 com.amazonaws.services.simpleemail.AmazonSimpleEmailServiceClient.sendEmail。如果您使用它,请将您的代码授权添加到 sendmail:Unable to send email from Amazon EC2 Server in Java

于 2013-04-19T03:31:41.623 回答