记录一下若依集成发送邮件


想在博客里评论时添加邮件提醒!!!


说干就干!!!

image.png


1、添加pom依赖

<!-- 邮件依赖 -->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-mail</artifactId>
</dependency>


2、配置yml

# Spring配置
spring:
  # 邮箱配置
  mail:
    host: smtp.qq.com
    username: *******@qq.com
    #邮箱授权码
    password: **********
    properties:
      mail:
        smtp:
          socketFactory:
            class: javax.net.ssl.SSLSocketFactory
            port: 465
          ssl:
            trust: smtp.qq.com
          auth: true
          starttls:
            enable: true
          required: true
    form: ${spring.mail.username}


3、开始使用

api.js

import request from '@/utils/customer-request'

// 发送简单邮件 
export function sendSimpleEmail(query) {
  return request({
    url: '/email/customer/sendSimpleEmail',
    method: 'post',
    data: query
  })
}

// 发送简单邮件 
export function sendHtmlEmail(query) {
  return request({
    url: '/email/customer/sendHtmlEmail',
    method: 'post',
    data: query
  })
}

vue文件

let email ={
    receiverEmail: '接收邮箱',
    subject: '主题',
    content: `邮件内容`
}
sendHtmlEmail(email).then(response =&gt; {
    if (response.code === 200) {
        this.$notify({
        message: '已通知博主'
        });
    }
});

实体类(get,set,toString方法就不放了)

/**
 * 邮件记录对象 px_email
 *
 * @author phy
 * @date 2021-05-13
 */
public class PxEmail extends BaseEntity {
    private static final long serialVersionUID = 1L;

    /**
     * 主键ID
     */
    private Long id;

    /**
     * 发送者ID
     */
    @Excel(name = "发送者ID")
    private Long sendId;

    /**
     * 收件人ID
     */
    @Excel(name = "收件人ID")
    private Long receiverId;

    /**
     * 收件人邮箱
     */
    @Excel(name = "收件人邮箱")
    private String receiverEmail;

    /**
     * 抄送人id,多个用逗号分隔
     */
    @Excel(name = "抄送人id,多个用逗号分隔")
    private Long ccId;

    /**
     * 抄送人邮箱,多个用逗号分隔
     */
    @Excel(name = "抄送人邮箱,多个用逗号分隔")
    private String ccEmail;

    /**
     * 邮件主题
     */
    @Excel(name = "邮件主题")
    private String subject;

    /**
     * 邮件内容
     */
    @Excel(name = "邮件内容")
    private String content;

    /**
     * 版本号
     */
    @Excel(name = "版本号")
    private String version;
}

ctroller(这里我把所有的逻辑都放到了controller了)

    @Resource
    private JavaMailSender javaMailSender;
    @Value("${spring.mail.username}")
    private String from;

    @ApiOperation("发送简单邮件")
    @PostMapping("/admin/sendSimpleEmail")
    public AjaxResult sendAdminSimpleEmail(@RequestBody PxEmail email) throws Exception {
        String[] to = validEmail(email.getReceiverEmail());
        if (to != null && to.length > 0) {
            try {
                SimpleMailMessage message = new SimpleMailMessage();
                message.setTo(to);
                if (StringUtils.isNotEmpty(email.getCcEmail())) {
                    message.setCc(Objects.requireNonNull(validEmail(email.getCcEmail())));
                }
                message.setSubject(email.getSubject());
                message.setText(email.getContent());
                message.setFrom(from);
                javaMailSender.send(message);
            } catch (Exception e) {
                invalidAddress(email, e);
                sendSimpleMail(email);
                e.printStackTrace();
            }

        }
        return AjaxResult.success("发送成功");
    }

    @ApiOperation("发送HTML邮件")
    @PostMapping("/admin/sendHtmlEmail")
    public AjaxResult sendAdminHtmlEmail(@RequestBody PxEmail email) {
        pxAdminEmailService.insertPxEmail(email);
        String[] to = validEmail(email.getReceiverEmail());
        if (to != null && to.length > 0) {
            try {
                MimeMessage message = javaMailSender.createMimeMessage();
                MimeMessageHelper helper = new MimeMessageHelper(message, true);
                helper.setFrom(from);
                helper.setTo(to);
                if (StringUtils.isNotEmpty(email.getCcEmail())) {
                    helper.setCc(Objects.requireNonNull(validEmail(email.getCcEmail())));
                }
                helper.setSubject(email.getSubject());
                helper.setText(email.getContent(), true);
                javaMailSender.send(message);
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
        return AjaxResult.success("发送成功");
    }

大功告成!!!

image.png
评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

Pei你看雪 .

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

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

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

打赏作者

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

抵扣说明:

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

余额充值