JavaMail不适用于Amazon EC2

时间:2013-04-11 18:29:04

标签: java amazon-ec2 tomcat7 javamail ubuntu-12.04


问题:

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


背景:

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

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


ERROR:

DEBUG 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. 我已经交叉检查了代码中提供的用户名和密码的正确性。

1 个答案:

答案 0 :(得分:7)

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

以下是描述部分历史记录的链接:http://shlomoswidler.com/2009/07/sending-email-from-ec2.html

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

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

      

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

         

    是的,您可以配置弹性IP的反向DNS记录   地址(提交Request to Remove Email Sending Limitations Form)。请注意,指向的对应转发DNS记录   在我们创建反向之前,弹性IP地址必须存在   DNS记录。

    以下是亚马逊在电子邮件配额耗尽时发送的电子邮件示例 - 再次拼写出请求&amp;批准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发送邮件,还需要请求,批准和适当的亚马逊提供的配置。这允许通过com.amazonaws.services.simpleemail.AmazonSimpleEmailServiceClient.sendEmail发送邮件。如果您使用此功能,请将代码的授权添加到sendmail:Unable to send email from Amazon EC2 Server in Java

相关问题