16

这段代码有什么问题?不知何故,它进入了一个无限循环 Transport.send(message);,没有错误消息,没有异常,只是可能无限循环(我不知道,因为我等待的时间不超过 5-10 分钟)

final String username = "<mail_name>";
final String password = "<password>";

Properties props = new Properties();
props.put("mail.smtp.auth", "true");
props.put("mail.smtp.starttls.enable", "true");
props.put("mail.smtp.host", "smtp.gmail.com");
props.put("mail.smtp.port", "465");

Session session = Session.getInstance(props,
        new javax.mail.Authenticator() {
            protected PasswordAuthentication getPasswordAuthentication() {
                return new PasswordAuthentication(username, password);
            }
        });

try {

    Message message = new MimeMessage(session);
    message.setFrom(new InternetAddress("<mail_from>@gmail.com"));
    message.setRecipients(Message.RecipientType.TO,
            InternetAddress.parse("<mail_to>@gmail.com"));
    message.setSubject("Test Subject");
    message.setText("Test");

    Transport.send(message);

    System.out.println("Done");

} catch (MessagingException e) {
    throw new RuntimeException(e);
}
4

4 回答 4

20

在这里,我进行了一些更改,这对我来说很好:

Session session = Session.getInstance(props,null);

你像你一样实例化消息对象。最后:

Transport transport = session.getTransport("smtp");
String mfrom = "yourGmailUsernameWithout@"// example laabidiraissi 
transport.connect("smtp.gmail.com", mfrom, "thepassword");
transport.sendMessage(message, message.getAllRecipients());

编辑,请您帮我一个忙并复制/粘贴并尝试此示例并显示它显示的内容:

package com.test;

import java.util.Properties;

import javax.mail.BodyPart;
import javax.mail.Message;
import javax.mail.MessagingException;
import javax.mail.Multipart;
import javax.mail.Session;
import javax.mail.Transport;
import javax.mail.internet.AddressException;
import javax.mail.internet.InternetAddress;
import javax.mail.internet.MimeBodyPart;
import javax.mail.internet.MimeMessage;
import javax.mail.internet.MimeMultipart;

import org.junit.Test;

public class EmailService {

@Test
public void test(){
    Properties props = System.getProperties();
    props.put("mail.smtp.starttls.enable", true); // added this line
    props.put("mail.smtp.host", "smtp.gmail.com");
    props.put("mail.smtp.user", "username");
    props.put("mail.smtp.password", "password");
    props.put("mail.smtp.port", "587");
    props.put("mail.smtp.auth", true);



    Session session = Session.getInstance(props,null);
    MimeMessage message = new MimeMessage(session);

    System.out.println("Port: "+session.getProperty("mail.smtp.port"));

    // Create the email addresses involved
    try {
        InternetAddress from = new InternetAddress("username");
        message.setSubject("Yes we can");
        message.setFrom(from);
        message.addRecipients(Message.RecipientType.TO, InternetAddress.parse("receivermail"));

        // Create a multi-part to combine the parts
        Multipart multipart = new MimeMultipart("alternative");

        // Create your text message part
        BodyPart messageBodyPart = new MimeBodyPart();
        messageBodyPart.setText("some text to send");

        // Add the text part to the multipart
        multipart.addBodyPart(messageBodyPart);

        // Create the html part
        messageBodyPart = new MimeBodyPart();
        String htmlMessage = "Our html text";
        messageBodyPart.setContent(htmlMessage, "text/html");


        // Add html part to multi part
        multipart.addBodyPart(messageBodyPart);

        // Associate multi-part with message
        message.setContent(multipart);

        // Send message
        Transport transport = session.getTransport("smtp");
        transport.connect("smtp.gmail.com", "username", "password");
        System.out.println("Transport: "+transport.toString());
        transport.sendMessage(message, message.getAllRecipients());


    } catch (AddressException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    } catch (MessagingException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    }
}
}
于 2013-03-24T12:04:51.120 回答
3

好的。它比我第一次提出的要复杂一些......总结一下我得到的:

  • 有一个非常有用的命令:session.setDebug(true);. 如果你设置为真,每一个重要的进程都会被调试到控制台。我建议使用它。
  • 第二台计算机只能使用安全选项,您可以将其切换为:Transport transport = session.getTransport("smtps");而不是非安全 smtp... JavaMail API 传输对象也将处理端口(分别为 smtp:587,smtps:465)
  • 您也可以使用 Transport 类的静态方法发送消息和(之前保存,非静态 sendMessage 方法不会保存消息),但是这次您需要在会话创建时使用 javax.mail.Authenticator,像这样:

    Session session = Session.getInstance(props,         new javax.mail.Authenticator() {
        protected PasswordAuthentication getPasswordAuthentication() {
            return new PasswordAuthentication("login", "password");
        }
    

    });

1.4.2 JavaMailApi 对于这个问题有另一个 1.4.7 版本之外的异常...

如果不使用它,则无法使用静态方法进行身份验证。如果你使用实例方法,你可以。

  • 一台计算机有 maven 并获得了 JavaMail API 的 1.4.2 版本。第二台计算机有一个下载的库,版本为 1.4.7,我想这也搞砸了
  • 第一个比较 Netbeans,第二个比较 Intellij ... +1) 互联网上有很多旧的和糟糕的示例代码,这使得正确使用这个 API 变得更加困难。

太乱了,但有一些基本概念应该集中......

于 2013-03-24T23:40:33.580 回答
1

我可以重现您问题中描述的行为并修复它。

send方法卡在

SMTPTransport(Service).connect(String, int, String, String) line: 308   

连接不成功,因为您的 gmail smtp 主机端口错误:465

将其更改为587

props.put("mail.smtp.port", "587");

它会起作用。

于 2013-03-24T12:27:05.670 回答
1

使用Simple Java Mail应该很简单:

Email email = new Email();

email.setFromAddress("lollypop", "lol.pop@somemail.com");
email.addRecipient("C.Cane", "candycane@candyshop.org", RecipientType.TO);
email.setText("We should meet up!");
email.setTextHTML("<b>We should meet up!</b>");
email.setSubject("hey");

new Mailer("smtp.gmail.com", 25, "your user", "your password", TransportStrategy.SMTP_TLS).sendMail(email);
new Mailer("smtp.gmail.com", 587, "your user", "your password", TransportStrategy.SMTP_TLS).sendMail(email);
new Mailer("smtp.gmail.com", 465, "your user", "your password", TransportStrategy.SMTP_SSL).sendMail(email);

如果您启用了双因素登录,则需要从您的 Google 帐户生成应用程序专用密码。

于 2016-05-19T11:11:50.043 回答