java中使用java扩展包下的mail实现邮件发送

java中使用java扩展包下的mail实现邮件发送

前言

Java中经常需要使用发送邮件的场景 ,比如日志告警,某些任务运行情况,当无人值守的时候,系统出现了问题,需要系统自动发送邮件给到运维人员。所以实现自动发送邮件是java开发人员必掌握的技能之一。

下面介绍实现办法,我们使用的是java扩展包下的mail包实现java发送邮件 。

一、发送邮件

    @ActionConstructInit(parameterVoName = "msgEmail", paramModel = MsgEmailModel.class)
    public void sendEmail() {//抛异常的方式处理失败
        // 根据模板ID,查询并处理
        msgEmailTemplate = getMsgEmailTemplate();
        msgEmailTemplate.setType(msgEmail.getTemplateType());
        msgEmailTemplate = msgEmailTemplate.load();
        if (msgEmailTemplate == null) {
            throw new MessageException(CommonException.MSG_SMS_SEND_NO_TEMPLATE, "短信发送模板未设置");
        }
        String content = msgEmailTemplate.getContent();

        //获取参数数据
        msgSmsParamsModel = getMsgSmsParamsModel();

        MsgSmsShareParamsModel msgSmsShareParamsModel = JSONUtility.jsonToObject(msgEmail.getParams(), MsgSmsShareParamsModel.class);
        for (Field field : msgSmsShareParamsModel.getClass().getDeclaredFields()) {
            if (ReflectionUtils.recursiveAttribute(msgSmsShareParamsModel, field.getName()) != null) {
                content = content.replace("{" + field.getName() + "}", ReflectionUtils.recursiveAttribute(msgSmsShareParamsModel, field.getName()) + "");
            }
        }

        for (Field field : msgSmsShareParamsModel.getClass().getSuperclass().getDeclaredFields()) {
            if (ReflectionUtils.recursiveAttribute(msgSmsShareParamsModel, field.getName()) != null) {
                content = content.replace("{" + field.getName() + "}", ReflectionUtils.recursiveAttribute(msgSmsShareParamsModel, field.getName()) + "");
            }
        }
        //拼装数据
        msgEmail.setTitle(msgEmailTemplate.getName());
        msgEmail.setContent(content);
        msgEmail.setCreateTime(new Date());
        //调用邮件发送工具类发送
        Application.doStaticExecute("message.email.send", this);
        msgEmail.setStatus(MsgEmail.STATUS_SUCCESS);
        msgEmail.update();
    }

工具类

    public static Boolean sendMail(String title,String content,List<MailModel> receiveMails){
        try {
            //发件人邮箱 {"name":"商城","mailAddress":"17710028852@163.com","password":"***","host":"smtp.163.com"}
            /*String mailSetting = SystemConfig.getSysConf(GlobalConfKey.CNF_SYS_SENDMAIL_SETTING);*/
            //String mailSetting = "{\"name\":\"张先生\",\"mailAddress\":\"zhang17746527715@163.com\",\"password\":\"zhang1994\",\"host\":\"smtp.163.com\"}";
            String mailSetting = ConfigDao.getAppConfig().getConfig("mail.setting");
            if(StringUtils.isBlank(mailSetting)){
                logger.info("邮件发送失败:没有设置发送人信息");
                return false;
            }
            if(receiveMails==null||receiveMails.size()==0){
                logger.info("邮件发送失败:没有设置发送人信息");
                return false;
            }
            logger.info("邮件发送参数:title:{}--{}--{}",title,mailSetting,receiveMails);
            //MailPo mailPo = JSON.parseObject(mailSetting,MailPo.class);
            MailModel mailPo = JSONUtility.jsonToObject(mailSetting, MailModel.class);
            //JSONObject parse = JSONObject.parse(mailSetting);
//            MailPo mailPo = JSONUtility.jsonToObject(mailSetting, MailPo.class);
            //MailPo mailPo = Utility.copyObject(parse, MailPo.class);

            //Object o = JSONUtility.jsonToObject(mailSetting, MailPo.class);
            // 1. 创建参数配置, 用于连接邮件服务器的参数配置
            Properties props = new Properties();                    // 参数配置
            props.setProperty("mail.transport.protocol", "smtp");   // 使用的协议(JavaMail规范要求)
            props.setProperty("mail.smtp.host", mailPo.getHost());   // 发件人的邮箱的 SMTP 服务器地址
            props.setProperty("mail.smtp.auth", "true");            // 需要请求认证


            // PS: 某些邮箱服务器要求 SMTP 连接需要使用 SSL 安全认证 (为了提高安全性, 邮箱支持SSL连接, 也可以自己开启),
            //     如果无法连接邮件服务器, 仔细查看控制台打印的 log, 如果有有类似 “连接失败, 要求 SSL 安全连接” 等错误,
            //     打开下面 /* ... */ 之间的注释代码, 开启 SSL 安全连接。
            /*
            // SMTP 服务器的端口 (非 SSL 连接的端口一般默认为 25, 可以不添加, 如果开启了 SSL 连接,
            //                  需要改为对应邮箱的 SMTP 服务器的端口, 具体可查看对应邮箱服务的帮助,
            //                  QQ邮箱的SMTP(SLL)端口为465或587, 其他邮箱自行去查看)
            final String smtpPort = "465";
            props.setProperty("mail.smtp.port", smtpPort);
            props.setProperty("mail.smtp.socketFactory.class", "javax.net.ssl.SSLSocketFactory");
            props.setProperty("mail.smtp.socketFactory.fallback", "false");
            props.setProperty("mail.smtp.socketFactory.port", smtpPort);
            */
            if(StringUtils.isNotBlank(mailPo.getPort())){
                props.setProperty("mail.smtp.port", mailPo.getPort());
                props.setProperty("mail.smtp.socketFactory.class", "javax.net.ssl.SSLSocketFactory");
                props.setProperty("mail.smtp.socketFactory.fallback", "false");
                props.setProperty("mail.smtp.socketFactory.port", mailPo.getPort());
            }
            // 2. 根据配置创建会话对象, 用于和邮件服务器交互
            Session session = Session.getInstance(props);
            session.setDebug(true);                                 // 设置为debug模式, 可以查看详细的发送 log

            // 3. 创建一封邮件
            MimeMessage message = createSimpleMessage(session, mailPo, receiveMails,title,content);

            // 4. 根据 Session 获取邮件传输对象
            Transport transport = session.getTransport();

            // 5. 使用 邮箱账号 和 密码 连接邮件服务器, 这里认证的邮箱必须与 message 中的发件人邮箱一致, 否则报错
            //
            //    PS_01: 成败的判断关键在此一句, 如果连接服务器失败, 都会在控制台输出相应失败原因的 log,
            //           仔细查看失败原因, 有些邮箱服务器会返回错误码或查看错误类型的链接, 根据给出的错误
            //           类型到对应邮件服务器的帮助网站上查看具体失败原因。
            //
            //    PS_02: 连接失败的原因通常为以下几点, 仔细检查代码:
            //           (1) 邮箱没有开启 SMTP 服务;
            //           (2) 邮箱密码错误, 例如某些邮箱开启了独立密码;
            //           (3) 邮箱服务器要求必须要使用 SSL 安全连接;
            //           (4) 请求过于频繁或其他原因, 被邮件服务器拒绝服务;
            //           (5) 如果以上几点都确定无误, 到邮件服务器网站查找帮助。
            //
            //    PS_03: 仔细看log, 认真看log, 看懂log, 错误原因都在log已说明。
            transport.connect(mailPo.getMailAddress(), mailPo.getPassword());

            // 6. 发送邮件, 发到所有的收件地址, message.getAllRecipients() 获取到的是在创建邮件对象时添加的所有收件人, 抄送人, 密送人
            transport.sendMessage(message, message.getAllRecipients());

            // 7. 关闭连接
            transport.close();
        }catch (Exception e){
            e.printStackTrace();
            logger.info("邮件发送异常:"+e.getMessage(),e);
            return false;
        }
        return true;
    }

    public static Boolean sendMail(String title,String content,List<MailModel> receiveMails){
        try {
            //发件人邮箱 {"name":"商城","mailAddress":"17710028852@163.com","password":"***","host":"smtp.163.com"}
            /*String mailSetting = SystemConfig.getSysConf(GlobalConfKey.CNF_SYS_SENDMAIL_SETTING);*/
            //String mailSetting = "{\"name\":\"张先生\",\"mailAddress\":\"zhang17746527715@163.com\",\"password\":\"zhang1994\",\"host\":\"smtp.163.com\"}";
            String mailSetting = ConfigDao.getAppConfig().getConfig("mail.setting");
            if(StringUtils.isBlank(mailSetting)){
                logger.info("邮件发送失败:没有设置发送人信息");
                return false;
            }
            if(receiveMails==null||receiveMails.size()==0){
                logger.info("邮件发送失败:没有设置发送人信息");
                return false;
            }
            logger.info("邮件发送参数:title:{}--{}--{}",title,mailSetting,receiveMails);
            //MailPo mailPo = JSON.parseObject(mailSetting,MailPo.class);
            MailModel mailPo = JSONUtility.jsonToObject(mailSetting, MailModel.class);
            //JSONObject parse = JSONObject.parse(mailSetting);
//            MailPo mailPo = JSONUtility.jsonToObject(mailSetting, MailPo.class);
            //MailPo mailPo = Utility.copyObject(parse, MailPo.class);

            //Object o = JSONUtility.jsonToObject(mailSetting, MailPo.class);
            // 1. 创建参数配置, 用于连接邮件服务器的参数配置
            Properties props = new Properties();                    // 参数配置
            props.setProperty("mail.transport.protocol", "smtp");   // 使用的协议(JavaMail规范要求)
            props.setProperty("mail.smtp.host", mailPo.getHost());   // 发件人的邮箱的 SMTP 服务器地址
            props.setProperty("mail.smtp.auth", "true");            // 需要请求认证


            // PS: 某些邮箱服务器要求 SMTP 连接需要使用 SSL 安全认证 (为了提高安全性, 邮箱支持SSL连接, 也可以自己开启),
            //     如果无法连接邮件服务器, 仔细查看控制台打印的 log, 如果有有类似 “连接失败, 要求 SSL 安全连接” 等错误,
            //     打开下面 /* ... */ 之间的注释代码, 开启 SSL 安全连接。
            /*
            // SMTP 服务器的端口 (非 SSL 连接的端口一般默认为 25, 可以不添加, 如果开启了 SSL 连接,
            //                  需要改为对应邮箱的 SMTP 服务器的端口, 具体可查看对应邮箱服务的帮助,
            //                  QQ邮箱的SMTP(SLL)端口为465或587, 其他邮箱自行去查看)
            final String smtpPort = "465";
            props.setProperty("mail.smtp.port", smtpPort);
            props.setProperty("mail.smtp.socketFactory.class", "javax.net.ssl.SSLSocketFactory");
            props.setProperty("mail.smtp.socketFactory.fallback", "false");
            props.setProperty("mail.smtp.socketFactory.port", smtpPort);
            */
            if(StringUtils.isNotBlank(mailPo.getPort())){
                props.setProperty("mail.smtp.port", mailPo.getPort());
                props.setProperty("mail.smtp.socketFactory.class", "javax.net.ssl.SSLSocketFactory");
                props.setProperty("mail.smtp.socketFactory.fallback", "false");
                props.setProperty("mail.smtp.socketFactory.port", mailPo.getPort());
            }
            // 2. 根据配置创建会话对象, 用于和邮件服务器交互
            Session session = Session.getInstance(props);
            session.setDebug(true);                                 // 设置为debug模式, 可以查看详细的发送 log

            // 3. 创建一封邮件
            MimeMessage message = createSimpleMessage(session, mailPo, receiveMails,title,content);

            // 4. 根据 Session 获取邮件传输对象
            Transport transport = session.getTransport();

            // 5. 使用 邮箱账号 和 密码 连接邮件服务器, 这里认证的邮箱必须与 message 中的发件人邮箱一致, 否则报错
            //
            //    PS_01: 成败的判断关键在此一句, 如果连接服务器失败, 都会在控制台输出相应失败原因的 log,
            //           仔细查看失败原因, 有些邮箱服务器会返回错误码或查看错误类型的链接, 根据给出的错误
            //           类型到对应邮件服务器的帮助网站上查看具体失败原因。
            //
            //    PS_02: 连接失败的原因通常为以下几点, 仔细检查代码:
            //           (1) 邮箱没有开启 SMTP 服务;
            //           (2) 邮箱密码错误, 例如某些邮箱开启了独立密码;
            //           (3) 邮箱服务器要求必须要使用 SSL 安全连接;
            //           (4) 请求过于频繁或其他原因, 被邮件服务器拒绝服务;
            //           (5) 如果以上几点都确定无误, 到邮件服务器网站查找帮助。
            //
            //    PS_03: 仔细看log, 认真看log, 看懂log, 错误原因都在log已说明。
            transport.connect(mailPo.getMailAddress(), mailPo.getPassword());

            // 6. 发送邮件, 发到所有的收件地址, message.getAllRecipients() 获取到的是在创建邮件对象时添加的所有收件人, 抄送人, 密送人
            transport.sendMessage(message, message.getAllRecipients());

            // 7. 关闭连接
            transport.close();
        }catch (Exception e){
            e.printStackTrace();
            logger.info("邮件发送异常:"+e.getMessage(),e);
            return false;
        }
        return true;
    }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

奋力向前123

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值