SpringBoot-JavaMailSender接口实战

海哥  金牌会员 | 2022-10-10 21:21:41 | 显示全部楼层 | 阅读模式
打印 上一主题 下一主题

主题 539|帖子 539|积分 1617

相信使用过Spring的众多开发者都知道Spring提供了非常好用的JavaMailSender接口实现邮件发送,在Spring Boot的Starter模块中也为此提供了自动化配置。
下面通过实例来讲解如何在Spring Boot中使用JavaMailSender发送邮件。
什么是SMTP?

SMTP全称为Simple Mail Transfer Protocol(简单邮件传输协议),它是一组用于从源地址到目的地址传输邮件的规范,通过它来控制邮件的中转方式。SMTP认证要求必须提供账号和密码才能登陆服务器,其设计目的在于避免用户受到垃圾邮件的侵扰。
什么是POP3?

POP3全称为Post Office Protocol 3(邮局协议),POP3支持客户端远程管理服务器端的邮件。POP3常用于“离线”邮件处理,即允许客户端下载服务器邮件,然后服务器上的邮件将会被删除。目前很多POP3的邮件服务器只提供下载邮件功能,服务器本身并不删除邮件,这种属于改进版的POP3协议。
传输协议

SMTP协议
发送邮件:我们通常把处理用户smtp请求(邮件发送请求)的服务器称之为SMTP服务器(邮件发送服务器)。
POP3协议
接收邮件:我们通常把处理用户pop3请求(邮件接收请求)的服务器称之为POP3服务器(邮件接收服务器)。
进阶知识


  • 什么是JavaMailSender和JavaMailSenderImpl?
JavaMailSender和JavaMailSenderImpl 是Spring官方提供的集成邮件服务的接口和实现类,以简单高效的设计著称,目前是Java后端发送邮件和集成邮件服务的主流工具。

  • 如何通过JavaMailSenderImpl发送邮件?‘
非常简单,直接在业务类注入JavaMailSenderImpl并调用send方法发送邮件其中简单邮件可以通过SimpleMailMessage来发送邮件,而复杂的邮件(例如添加附件)可以借助MimeMessageHelper来构建MimeMessage发送邮件
e,g:
  1.     @Autowired
  2.     private JavaMailSenderImpl mailSender;
  3.     public void sendMail() throws MessagingException {
  4.         //简单邮件
  5.         SimpleMailMessage simpleMailMessage = new SimpleMailMessage();
  6.         simpleMailMessage.setFrom("admin@163.com");
  7.         simpleMailMessage.setTo("socks@qq.com");
  8.         simpleMailMessage.setSubject("Happy New Year");
  9.         simpleMailMessage.setText("新年快乐!");
  10.         mailSender.send(simpleMailMessage);
  11.         //复杂邮件
  12.         MimeMessage mimeMessage = mailSender.createMimeMessage();
  13.         MimeMessageHelper messageHelper = new MimeMessageHelper(mimeMessage);
  14.         messageHelper.setFrom("admin@163.com");
  15.         messageHelper.setTo("socks@qq.com");
  16.         messageHelper.setSubject("Happy New Year");
  17.         messageHelper.setText("新年快乐!");
  18.         messageHelper.addInline("doge.gif", new File("xx/xx/doge.gif"));
  19.         messageHelper.addAttachment("work.docx", new File("xx/xx/work.docx"));
  20.         mailSender.send(mimeMessage);
  21.     }
复制代码

  • 为什么JavaMailSenderImpl 能够开箱即用 ?
    所谓开箱即用其实就是基于官方内置的自动配置,翻看源码可知晓邮件自动配置类(MailSenderPropertiesConfiguration) 为上下文提供了邮件服务实例(JavaMailSenderImpl)。具体源码如下:
  1. @Configuration
  2. @ConditionalOnProperty(prefix = "spring.mail", name = "host")
  3. class MailSenderPropertiesConfiguration {
  4.     private final MailProperties properties;
  5.     MailSenderPropertiesConfiguration(MailProperties properties) {
  6.         this.properties = properties;
  7.     }
  8.     @Bean
  9.     @ConditionalOnMissingBean
  10.     public JavaMailSenderImpl mailSender() {
  11.         JavaMailSenderImpl sender = new JavaMailSenderImpl();
  12.         applyProperties(sender);
  13.         return sender;
  14. }
复制代码
其中MailProperties是关于邮件服务器的配置信息,具体源码如下:
  1. @ConfigurationProperties(prefix = "spring.mail")
  2. public class MailProperties {
  3.     private static final Charset DEFAULT_CHARSET = StandardCharsets.UTF_8;
  4.     private String host;
  5.     private Integer port;
  6.     private String username;
  7.     private String password;
  8.     private String protocol = "smtp";
  9.     private Charset defaultEncoding = DEFAULT_CHARSET;
  10.     private Map<String, String> properties = new HashMap<>();
  11. }
复制代码
实现

1.开启邮件服务

这里以QQ邮箱为例。
首先登录QQ邮箱>>>登录成功后找到设置>>>然后找到邮箱设置>>>点击账户>>>找到POP3|SMTP服务>>>点击开启(开启需要验证,验证成功后会有一串授权码用于发送邮件使用)>>>验证成功
<img alt="image-20221008154945207" loading="lazy">
引入依赖

在springboot项目中,引入如下依赖:
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  3.          xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
  4.     <modelVersion>4.0.0</modelVersion>
  5.     <parent>
  6.         <groupId>org.springframework.boot</groupId>
  7.         <artifactId>spring-boot-starter-parent</artifactId>
  8.         <version>2.7.4</version>
  9.         <relativePath/>
  10.     </parent>
  11.     <groupId>com.galaxy</groupId>
  12.     <artifactId>MailSender</artifactId>
  13.     <version>0.0.1-SNAPSHOT</version>
  14.     <name>MailSender</name>
  15.     <description>MailSender</description>
  16.     <properties>
  17.         <java.version>1.8</java.version>
  18.     </properties>
  19.     <dependencies>
  20.         <dependency>
  21.             <groupId>org.springframework.boot</groupId>
  22.             <artifactId>spring-boot-starter-web</artifactId>
  23.         </dependency>
  24.         <dependency>
  25.             <groupId>org.springframework.boot</groupId>
  26.             <artifactId>spring-boot-starter-test</artifactId>
  27.             <scope>test</scope>
  28.         </dependency>
  29.         <dependency>
  30.             <groupId>org.springframework.boot</groupId>
  31.             <artifactId>spring-boot-starter-mail</artifactId>
  32.         </dependency>
  33.         <dependency>
  34.             <groupId>org.apache.commons</groupId>
  35.             <artifactId>commons-lang3</artifactId>
  36.             <version>3.10</version>
  37.         </dependency>
  38.     </dependencies>
  39.     <build>
  40.         <plugins>
  41.             <plugin>
  42.                 <groupId>org.springframework.boot</groupId>
  43.                 <artifactId>spring-boot-maven-plugin</artifactId>
  44.             </plugin>
  45.         </plugins>
  46.     </build>
  47. </project>
复制代码
application.yml配置

在配置文件application.yml文件中写入发送邮件的配置信息
  1. # 服务端口
  2. server:
  3.   port: 8083
  4. spring:
  5.   #邮箱基本配置
  6.   mail:
  7.     #配置smtp服务主机地址
  8.     # qq邮箱为smtp.qq.com          端口号465或587
  9.     # sina    smtp.sina.cn
  10.     # aliyun  smtp.aliyun.com
  11.     # 163     smtp.163.com       端口号465或994
  12.     host: smtp.qq.com
  13.     #发送者邮箱
  14.     username: 896668626@qq.com
  15.     #配置密码,注意不是真正的密码,而是刚刚申请到的授权码
  16.     password: gltiixjllkakxobfjd
  17.     #端口号465或587
  18.     port: 587
  19.     #默认的邮件编码为UTF-8
  20.     default-encoding: UTF-8
  21.     #其他参数
  22.     properties:
  23.      mail:
  24.         #配置SSL 加密工厂
  25.       smtp:
  26.         ssl:
  27.           #本地测试,先放开ssl
  28.           enable: false
  29.           required: false
  30.         #开启debug模式,这样邮件发送过程的日志会在控制台打印出来,方便排查错误
  31.       debug: true
复制代码
注:配置 SpringBoot 启动端口还可以通过IDEA 本身的配置来指定启动端口

  • 第一步

  • 第二步

编写发送邮件方法

编写邮件业务类MailService.
主要通过MailService工具类就可以满足发送java邮件的需要。当我们进行好 yml 配置后,SpringBoot会帮助我们自动配置 JavaMailSender 我们通过这个java类就可以实现操作java来发送邮件。
发送纯文本邮件

service
  1. package com.galaxy.mailsender.service;
  2. import org.apache.commons.lang3.StringUtils;
  3. import org.springframework.beans.factory.annotation.Autowired;
  4. import org.springframework.beans.factory.annotation.Value;
  5. import org.springframework.mail.javamail.JavaMailSenderImpl;
  6. import org.springframework.mail.javamail.MimeMessageHelper;
  7. import org.springframework.stereotype.Service;
  8. import javax.mail.MessagingException;
  9. import java.util.Date;
  10. /**
  11. * 邮件业务类
  12. * @author Galaxy
  13. */
  14. @Service
  15. public class MailService {
  16.     /**
  17.      * 注入邮件工具类
  18.      */
  19.     @Autowired
  20.     private JavaMailSenderImpl javaMailSender;
  21.     @Value("${spring.mail.username}")
  22.     private String sendMailer;
  23.     /**
  24.      * 检测邮件信息类
  25.      * @param to
  26.      * @param subject
  27.      * @param text
  28.      */
  29.     private void checkMail(String to,String subject,String text){
  30.         if(StringUtils.isEmpty(to)){
  31.             throw new RuntimeException("邮件收信人不能为空");
  32.         }
  33.         if(StringUtils.isEmpty(subject)){
  34.             throw new RuntimeException("邮件主题不能为空");
  35.         }
  36.         if(StringUtils.isEmpty(text)){
  37.             throw new RuntimeException("邮件内容不能为空");
  38.         }
  39.     }
  40.     /**
  41.      * 发送纯文本邮件
  42.      * @param to
  43.      * @param subject
  44.      * @param text
  45.      */
  46.     public void sendTextMailMessage(String to,String subject,String text){
  47.         try {
  48.             //true 代表支持复杂的类型
  49.             MimeMessageHelper mimeMessageHelper = new MimeMessageHelper(javaMailSender.createMimeMessage(),true);
  50.             //邮件发信人
  51.             mimeMessageHelper.setFrom(sendMailer);
  52.             //邮件收信人  1或多个
  53.             mimeMessageHelper.setTo(to.split(","));
  54.             //邮件主题
  55.             mimeMessageHelper.setSubject(subject);
  56.             //邮件内容
  57.             mimeMessageHelper.setText(text);
  58.             //邮件发送时间
  59.             mimeMessageHelper.setSentDate(new Date());
  60.             //发送邮件
  61.             javaMailSender.send(mimeMessageHelper.getMimeMessage());
  62.             System.out.println("发送邮件成功:"+sendMailer+"->"+to);
  63.         } catch (MessagingException e) {
  64.             e.printStackTrace();
  65.             System.out.println("发送邮件失败:"+e.getMessage());
  66.         }
  67.     }
  68. }
复制代码
Controller
  1. package com.galaxy.mailsender.controller;
  2. import com.galaxy.mailsender.service.MailService;
  3. import org.springframework.beans.factory.annotation.Autowired;
  4. import org.springframework.web.bind.annotation.RequestMapping;
  5. import org.springframework.web.bind.annotation.RestController;
  6. @RestController
  7. public class MailController {
  8.     @Autowired
  9.     private MailService mailService;
  10.     /**
  11.      * 发送文本邮件
  12.      * @param to
  13.      * @param subject
  14.      * @param text
  15.      */
  16.     @RequestMapping("/sendTextMail")
  17.     public void sendTextMail(String to,String subject,String text){
  18.         mailService.sendTextMailMessage(to,subject,text);
  19.     }
  20. }
复制代码
测试



结果


补充

发送html邮件

Spring Boot支持使用HTML发送邮件是通过MimeMessage来完成的。
发送带附件的邮件

MimeMessageHelper支持发送复杂邮件模板,支持文本、附件、HTML、图片等。比如需要发送附件,则在上面的代码中通过调用helper的addAttachment(fileName, file)方法即可。
例:发送HTML邮件
  1. package com.example.emaildemo.controller;
  2. import com.example.emaildemo.service.MailService;
  3. import org.springframework.beans.factory.annotation.Autowired;
  4. import org.springframework.web.bind.annotation.RequestMapping;
  5. import org.springframework.web.bind.annotation.RestController;
  6. /**
  7. * 测试邮件发送
  8. * @author galaxy
  9. */
  10. @RestController
  11. public class SendMailController {
  12.     @Autowired
  13.     private MailService mailService;
  14.     /**
  15.      * 发送HTML邮件
  16.      * @param to
  17.      * @param subject
  18.      * @param content
  19.      */
  20.     @RequestMapping("/sendHtmlMailMessage")
  21.     public void sendHtmlMailMessage(String to,String subject,String content){
  22.         mailService.sendHtmlMailMessage(to,subject,content);
  23.     }
  24. }
复制代码
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

海哥

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表