JAVA代码发送邮件示例和解释(二)

简介: 之前有使用过一次在程序中发邮件的功能,也写了一篇相关的笔记,当时使用的是163邮箱,经过测试多个163账号都是可行的。但是最近把账号换成中国移动@chinamobilesz.com这种结尾的时候,却一直连接不上服务器,验证不通过,于是只好重新进行了一些改动,这期间也有参考另一个同事之前的写法,成功实现。 这种实现方式和上一种大同小异,只是经过测试后,这种方式不仅163的邮箱没有问题
之前有使用过一次在程序中发邮件的功能,也写了一篇相关的笔记,当时使用的是163邮箱,经过测试多个163账号都是可行的。但是最近把账号换成中国移动@ chinamobilesz.com这种结尾的时候,却一直连接不上服务器,验证不通过,于是只好重新进行了一些改动,这期间也有参考另一个同事之前的写法,成功实现。

这种实现方式和上一种大同小异,只是经过测试后,这种方式不仅163的邮箱没有问题, 中国移动@ chinamobilesz.com这种也可以,因此相对前边写的那种应该要更好一些,具体代码如下:
package test;

import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import java.util.Properties;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
import javax.activation.DataHandler;
import javax.activation.DataSource;
import javax.activation.FileDataSource;
import javax.mail.Address;
import javax.mail.BodyPart;
import javax.mail.Message;
import javax.mail.Session;
import javax.mail.Transport;
import javax.mail.internet.InternetAddress;
import javax.mail.internet.MimeBodyPart;
import javax.mail.internet.MimeMessage;
import javax.mail.internet.MimeMultipart;
import javax.mail.internet.MimeUtility;

public class SendMailTest1 {
    public static void main(String[] args) {
        SendMailTest1 send = new SendMailTest1();
        send.sendEmail();
    }

    /**
     * 
     * @Title: sendTextMail
     * @Description: TODO
     * @param mailInfo
     * @return
     */
    // MailModel mailInfo
    public boolean sendEmail() {
        // 从配置文件中读取配置信息
        Properties pro = new Properties();
        pro.put("mail.smtp.host", "mail.chinamobilesz.com");
        pro.put("mail.smtp.auth", "true");
        // Properties pro = mailConfig.getProperties();
        // 根据邮件的回话属性构造一个发送邮件的Session
        MailAuthenticator authenticator = new MailAuthenticator("账号",
                "密码");
        Session session = Session.getInstance(pro, authenticator);
        // 监控邮件命令
        try {
            // 根据Session 构建邮件信息
            Message message = new MimeMessage(session);
            // 创建邮件发送者地址
            Address from = new InternetAddress("xtyw");
            // 设置邮件消息的发送者
            message.setFrom(from);
            // 验证邮箱地址
            List<String> auth = new ArrayList<String>();
            auth.add("1160569243@qq.com");
            String toAddress = validateEmail(auth);
            if (!toAddress.isEmpty()) {
                // 创建邮件的接收者地址
                Address[] to = InternetAddress.parse(toAddress);
                // 设置邮件接收人地址
                message.setRecipients(Message.RecipientType.TO, to);
                message.setSubject("12345");
                // 邮件容器
                MimeMultipart mimeMultiPart = new MimeMultipart();
                // 设置HTML
                BodyPart bodyPart = new MimeBodyPart();
                String htmlText = "123456";
                bodyPart.setContent(htmlText, "text/html;charset=utf-8");
                mimeMultiPart.addBodyPart(bodyPart);
                // 添加附件
                List<String> fileList = new ArrayList<String>();
                fileList.add("C:\\Users\\tuzongxun123\\Desktop\\自主服务API.docx");

                if (fileList != null) {
                    BodyPart attchPart = null;
                    for (int i = 0; i < fileList.size(); i++) {
                        if (!fileList.get(i).isEmpty()) {
                            attchPart = new MimeBodyPart();
                            // 附件数据源
                            DataSource source = new FileDataSource(
                                    fileList.get(i));
                            // 将附件数据源添加到邮件体
                            attchPart.setDataHandler(new DataHandler(source));
                            // 设置附件名称为原文件名
                            attchPart.setFileName(MimeUtility.encodeText(source
                                    .getName()));
                            mimeMultiPart.addBodyPart(attchPart);
                        }
                    }
                }
                message.setContent(mimeMultiPart);
                message.setSentDate(new Date());
                // 保存邮件
                message.saveChanges();
                // 发送邮件
                Transport.send(message);
                return true;
            }
        } catch (Exception e) {
            e.printStackTrace();
            System.out.println("邮件发送失败");
        }
        return false;
    }

    /**
     * @title validateEmail
     * @Description 验证邮箱格式
     * @param emailList
     * @return string
     */
    public String validateEmail(List<String> emailList) {
        StringBuffer buffer = new StringBuffer();
        if (!emailList.isEmpty()) {
            String regEx = "^([a-z0-9A-Z]+[-|\\.]?)+[a-z0-9A-Z]@([a-z0-9A-Z]+(-[a-z0-9A-Z]+)?\\.)+[a-zA-Z]{2,}$";
            Pattern p = Pattern.compile(regEx);
            for (int i = 0; i < emailList.size(); i++) {
                Matcher match = p.matcher(emailList.get(i));
                if (match.matches()) {
                    buffer.append(emailList.get(i));
                    if (i < emailList.size() - 1) {
                        buffer.append(",");
                    }
                }
            }
        }
        return buffer.toString();
    }
}


目录
相关文章
|
15天前
|
Java
在 Java 中捕获和处理自定义异常的代码示例
本文提供了一个 Java 代码示例,展示了如何捕获和处理自定义异常。通过创建自定义异常类并使用 try-catch 语句,可以更灵活地处理程序中的错误情况。
|
29天前
|
XML 安全 Java
Java反射机制:解锁代码的无限可能
Java 反射(Reflection)是Java 的特征之一,它允许程序在运行时动态地访问和操作类的信息,包括类的属性、方法和构造函数。 反射机制能够使程序具备更大的灵活性和扩展性
39 5
Java反射机制:解锁代码的无限可能
|
25天前
|
jenkins Java 测试技术
如何使用 Jenkins 自动发布 Java 代码,通过一个电商公司后端服务的实际案例详细说明
本文介绍了如何使用 Jenkins 自动发布 Java 代码,通过一个电商公司后端服务的实际案例,详细说明了从 Jenkins 安装配置到自动构建、测试和部署的全流程。文中还提供了一个 Jenkinsfile 示例,并分享了实践经验,强调了版本控制、自动化测试等关键点的重要性。
60 3
|
1月前
|
存储 安全 Java
系统安全架构的深度解析与实践:Java代码实现
【11月更文挑战第1天】系统安全架构是保护信息系统免受各种威胁和攻击的关键。作为系统架构师,设计一套完善的系统安全架构不仅需要对各种安全威胁有深入理解,还需要熟练掌握各种安全技术和工具。
85 10
|
26天前
|
分布式计算 Java MaxCompute
ODPS MR节点跑graph连通分量计算代码报错java heap space如何解决
任务启动命令:jar -resources odps-graph-connect-family-2.0-SNAPSHOT.jar -classpath ./odps-graph-connect-family-2.0-SNAPSHOT.jar ConnectFamily 若是设置参数该如何设置
|
25天前
|
Java
Java代码解释++i和i++的五个主要区别
本文介绍了前缀递增(++i)和后缀递增(i++)的区别。两者在独立语句中无差异,但在赋值表达式中,i++ 返回原值,++i 返回新值;在复杂表达式中计算顺序不同;在循环中虽结果相同但使用方式有别。最后通过 `Counter` 类模拟了两者的内部实现原理。
Java代码解释++i和i++的五个主要区别
|
4月前
|
Java 数据安全/隐私保护
Java代码的执行顺序和构造方法
构造方法是类的一种特殊方法,用于初始化新对象。在 Java 中,每个类默认都有一个与类名同名的构造方法,无需返回类型。构造方法不能用 static、final、synchronized、abstract 或 native 修饰。它可以重载,通过不同的参数列表实现多种初始化方式。构造方法在对象实例化时自动调用,若未显式声明,默认提供一个无参构造方法。构造代码块和静态代码块分别用于对象和类的初始化,按特定顺序执行。
32 0
|
6月前
|
Java
Java代码的执行顺序
Java代码的执行顺序
34 1
|
Java
Java基础-代码执行顺序(重要)
Java代码初始化顺序:     1.由 static 关键字修饰的(如:类变量(静态变量)、静态代码块)将在类被初始化创建实例对象之前被初始化,而且是按顺序从上到下依次被执行。静态(类变量、静态代码块)属于类本身,不依赖于类的实例。     2.没有 static 关键字修饰的(如:实例变量(非静态变量)、非静态代码块)初始化实际上是会被提取到类的构造器中被执行的,但是会比类构造器中的代码
2368 1
LearnJava(四) | Java代码块执行顺序测试
最近笔试常常遇到考察Java代码块执行顺序的题目,网上查看博客错漏百出,特地自己测试了一下。 如有错漏,希望路过的大佬指出来,以便我进行更改。   先上代码吧! public class ClassA { private static St...
950 0