使用数据库以Java发送电子邮件

时间:2013-09-10 08:46:43

标签: java email smtp

我目前正在做一个项目,我需要向从数据库中获取的特定地址发送电子邮件。但是,数据库中的“email”列实际上并不包含电子邮件,而是包含名称。所以在数据库中有俄语的全名,如

“ИвановАлександр”是“Ivanov Alexandr”。因此,当我在outlook中输入此名称时,它会自动找到他的电子邮件:AIvanov@domainname.com。但在我的java代码中,当我使用名称“ИвановАлександр”时,我不断收到错误。

这是我的java代码

File[] listOfFiles = outDir.listFiles();
    if (outDir.isDirectory()) {
        if (outDir.list().length > 0) {
            for (File file : listOfFiles) {
                    Session session_m = Session.getDefaultInstance(props, null);
                    MimeMessage message = new MimeMessage(session_m);
                    message.setFrom (new InternetAddress("mmm@domainname.com", "mmm@domainname.com"));
                    InternetAddress i = new InternetAddress("\""+email+"\"", false);
                    message.addRecipient(Message.RecipientType.TO, i);
                    message.setSubject("test");
                    message.setText("test");
                    message.setHeader("Content-Type","text/plain;charset=windows-1251");

                    MimeBodyPart mbp1 = new MimeBodyPart();
                    FileDataSource fds = new FileDataSource(file);
                    mbp1.setDataHandler(new DataHandler(fds));
                    mbp1.setFileName(fds.getName());

                    Multipart mp = new MimeMultipart();
                    mp.addBodyPart(mbp1);

                    System.out.println("[EmailHandler] Attaching the following file to email: " + fds.getName());
                    message.setContent(mp);

                    SMTPTransport t = (SMTPTransport)session_m.getTransport("smtp");
                    t.connect("mail.domainname.com", "main@domainname.com", null);
                    System.out.println("[EmailHandler] Sending email... ");
                    t.sendMessage(message, message.getAllRecipients());
                    file.delete();
                    Thread.sleep(3000);
                }
            } else {
                System.out.println("[EmailHandler] Folder " + outDir.getName() + " is empty... nothing to attach");
            }
        } else {
            System.out.println("Folder not found... Check the path");
        }

在此代码中,字符串电子邮件是ИвановАлександр。

我一直收到这个错误

javax.mail.internet.AddressException:本地地址包含字符串“ИвановАлександр”中的控件或空格

所以想知道我可以让这个字符串通过的方法。

谢谢。

3 个答案:

答案 0 :(得分:1)

outlook使用其地址簿将名称映射到其中一个电子邮件。这就是为什么它工作正常,如果你手动尝试创建一个新的电子邮件,只需输入名称。 Outlook只需在地址簿中查找并查找电子邮件地址即可。

然而,这与java程序不同。该程序需要确切的电子邮件地址才能发送电子邮件现在可以通过多种方式查找电子邮件地址。

最简单的方法是将电子邮件地址存储在其中一个数据库表中。 如果此人与公司的SMTP系统/活动目录关联;您可以使用java smtp API /活动目录API查找电子邮件或别名(通常是@之前的电子邮件ID的一部分),然后创建用于发送电子邮件的程序的电子邮件ID。

答案 1 :(得分:0)

您需要提供有效的邮件地址。如果您使用固定结构的邮件,只需将名称转换为拉丁字符并附加@ domain.com 如果您没有使用任何规则来创建邮件地址,那么我建议您在数据库中添加一个电子邮件字段

不知道这是否可以解决你的问题

此致

答案 2 :(得分:0)

你的程序必须

  1. 验证电子邮件。 它可以使用正则表达式实现:Using a regular expression to validate an email address

  2. 当字段仅包含名称时,从联系人列表中获取电子邮件。有两个用于处理Outlook联系人的库: Open source java library to read outlook emails, calendar etc