栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

云e办学习笔记(二十七)邮件自动发送功能实现

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

云e办学习笔记(二十七)邮件自动发送功能实现

前言

本系列博客基于B站的云e办管理系统,前端和后端我都自己敲了一遍,这里做一个学习记录。云e办的原始视频链接如下:https://www.bilibili.com/video/BV1Ai4y1P7Tk?p=1


首先是去邮箱开启SMTP服务,然后我记得是得发手机验证码,然后它会生成一个授权字符串序列,保存这个授权码,待会会用。QQ邮箱我也尝试用过,不过要是不用SSL协议发送邮件,不建议用QQ邮箱(因为不好配置啊靓仔~)。

因为使用的是非SSL协议,所以得找准确自己使用的协议端口号和服务器地址。

新建模块

pom里面删除多余的东西

填入依赖,注意,第四个是自己服务模块的依赖,根据自己实际来改。

拷贝父工程——也就是服务层的坐标到邮件发送项目

新建Resource目录,写配置文件。

server:
  # 端口
  port: 8082
spring:
  # 邮件配置
  mail:
    # 邮件服务器地址
    host: smtp.163.com
    # 协议
    protocol: smtp
    # 编码格式
    default-encoding: utf-8
    # 授权码(在邮箱开通服务时获取)
    password: JVVFXSXZMRJNQZRH
    # 发送者邮箱地址
    username: dll13239644587@163.com
    # 端口(不同邮箱端口号不同)
    port: 25



#    #参数
#    properties:
#      mail.smtp.auth: true
#      mail.smtp.socketFactory.class: javax.net.ssl.SSLSocketFactory
#      mail.smtp.socketFactory.fallback: false
#      mail.smtp.socketFactory.port: 465



  # rabbitmq配置
  rabbitmq:
    # 用户名
    username: guest
    # 密码
    password: guest
    # 服务器地址
    host: 192.168.75.129
    # 端口
    port: 5672
    listener:
      simple:
        #开启手动确认
        acknowledge-mode: manual

  # Redis配置
  redis:
    timeout: 10000ms         # 连接超时时间
    host: 192.168.75.129     # Redis服务器地址
    port: 6379               # Redis服务器端口
    database: 0              # 选择哪个库,默认0库
    lettuce:
      pool:
        max-active: 1024     # 最大连接数,默认 8
        max-wait: 10000ms    # 最大连接阻塞等待时间,单位毫秒,默认 -1
        max-idle: 200        # 最大空闲连接,默认 8
        min-idle: 5          # 最小空闲连接,默认 0
    password: root
启动类

邮件内容页面


在服务模块加上rabbitMQ依赖(以自己实际为准)

然后去人员管理实现类修改添加员工的逻辑,首先获取要添加人员的信息,然后通过rabbitMQ来发送邮件内容


然后去邮件模块添加接收邮件的功能逻辑

package com.xxxx.mail;

import com.rabbitmq.client.Channel;
import com.xxxx.server.pojo.Employee;
import com.xxxx.server.pojo.MailConstants.MailConstants;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.amqp.rabbit.annotation.RabbitListener;
import org.springframework.amqp.support.AmqpHeaders;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.autoconfigure.mail.MailProperties;
import org.springframework.data.redis.core.HashOperations;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.mail.javamail.JavaMailSender;
import org.springframework.mail.javamail.MimeMailMessage;
import org.springframework.mail.javamail.MimeMessageHelper;
import org.springframework.messaging.Message;
import org.springframework.messaging.MessageHeaders;
import org.springframework.stereotype.Component;
import org.thymeleaf.TemplateEngine;
import org.thymeleaf.context.Context;

import javax.mail.MessagingException;
import javax.mail.internet.MimeMessage;
import java.io.IOException;
import java.util.Date;



@Component
public class MailReceiver {
    public static final Logger LOGGER = LoggerFactory.getLogger(MailReceiver.class);

    @Autowired
    private JavaMailSender javaMailSender;

    @Autowired
    private MailProperties mailProperties;

    @Autowired
    private TemplateEngine templateEngine;

    @Autowired
    private RedisTemplate redisTemplate;

    //写监听
    @RabbitListener(queues = MailConstants.MAIL_QUEUE_NAME)
    public void handler(Message message, Channel channel) {
        Employee employee = (Employee) message.getPayload();
        MessageHeaders headers = message.getHeaders();
        //消息序号
        long tag = (long) headers.get(AmqpHeaders.DELIVERY_TAG);
        String msgId = (String) headers.get("spring_returned_message_correlation");
        HashOperations hashOperations = redisTemplate.opsForHash();


        try {
            
            if (hashOperations.entries("mail_log").containsKey(msgId)) {
                LOGGER.error("消息已经被消费======>{}",msgId);
                
                channel.basicAck(tag,false);
                return;
            }

            MimeMessage msg = javaMailSender.createMimeMessage();
            MimeMessageHelper helper = new MimeMessageHelper(msg);
            helper.setFrom(mailProperties.getUsername());
            helper.setTo(employee.getEmail());
            helper.setSubject("欢迎邮件!");
            helper.setSentDate(new Date());

            Context context = new Context();
            context.setVariable("name",employee.getName());
            context.setVariable("posName",employee.getPosition().getName());
            context.setVariable("joblevelName",employee.getJoblevel().getName());
            context.setVariable("departmentName",employee.getDepartment().getName());

            //通过template引擎放入邮件内容
            String mail = templateEngine.process("mail",context);
            helper.setText(mail,true);
            //发送邮件
            javaMailSender.send(msg);
            LOGGER.info("邮件发送成功");
            //存入消息到Redis
            hashOperations.put("mail_log",msgId,"OK");
            //手动确认消息
            channel.basicAck(tag,false);

        } catch (Exception e) {
            try {
                
                channel.basicNack(tag,false,true);
            } catch (IOException ex) {
                LOGGER.error("邮件发送失败=======>{}",e.getMessage());
            }
            LOGGER.error("邮件发送失败=======>{}",e.getMessage());
        }
    }
}

首先是准备打印日志的logger## 注入邮件发送、邮件配置、模板引擎

rabbitMQ监听的消息队列即是定义的mail.welcome

方法里面准备发件人,收件人,主题,发送日期和邮件内容里面相关信息的设置。发送不成功就打印日志。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/872842.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号