本文已参与「新人创作礼」活动,一起开启掘金创作之路。

Spring 提供了非常好用的 JavaMailSender 接口实现邮件发送。在 SpringBoot 的 Starter 模块中也为此提供了自动化配置。下面通过实例看看如何在 SpringBoot 中使用 JavaMailSender 发送邮件。

一、使用 SpringBoot 创建 Java Web 项目,添加邮件相关依赖包

在 SpringBoot 工程中的 pom.xml 中引入 spring-boot-starter-mail 依赖。

<dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-mail</artifactId>
</dependency>

  由于 SpringBoot 的 starter 模块提供了自动化配置,所以在引入了 spring-boot-starter-mail 依赖之后,会根据配置文件 application.properties 中的内容去创建 JavaMailSender 实例,因此我们可以直接在需要使用的地方通过 @Autowired 来引入邮件发送对象 JavaMailSender。

二、 application.properties 配置邮件相关内容

  有些服务器没有网络代理,而有些服务器(例如生产环境)可能有 SMTP 邮件代理服务器,以下分别总结下有无代理服务器时的邮件相关配置。

  2.1 邮件配置(无代理)
spring.mail.host=此处填写邮件服务器
# SMTP 协议端口
spring.mail.port=465
spring.mail.username=此处填写发件箱
# 465 端口是 SSL 协议端口(非 SSL 协议端口是 25),还需要配置 SSL 协议相关内容
spring.mail.properties.mail.smtp.socketFactory.class=javax.net.ssl.SSLSocketFactory
spring.mail.properties.mail.smtp.ssl.enable=true
# 若开启服务端校验身份,需要设置如下 2 项参数。如不开启校验则无需设置。
spring.mail.password=发件箱密码
spring.mail.properties.mail.smtp.auth=true
  2.2 邮件配置(有代理)
# 此处填写代理服务器地址(此处配置的代理服务器地址是一个假 IP)
spring.mail.host=4.4.4.4
# 此处填写代理服务器端口(此处配置的代理服务器端口是一个假端口)
spring.mail.port=1089
# 发送邮件协议
spring.mail.protocol=smtp
spring.mail.username=[your email username]
spring.mail.properties.mail.smtp.timeout=25000
spring.mail.properties.mail.smtp.socketFactory.port=465
spring.mail.properties.mail.smtp.socketFactory.class=javax.net.ssl.SSLSocketFactory
spring.mail.properties.mail.smtp.ssl.enable=true
spring.mail.properties.mail.debug=true
spring.mail.password=[email password]
spring.mail.properties.mail.smtp.auth=true

  备注:有些邮件服务器的密码不是填真实的邮箱密码,而是授权码。如 QQ 邮箱等。

三、发送邮件代码示例
  3.1 发送简单邮件示例
package com.demo.mail.controller;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.mail.SimpleMailMessage;
import org.springframework.mail.javamail.JavaMailSender;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
public class MailController {
    private static Logger log = LoggerFactory.getLogger(MailController.class);
    @Autowired
    private JavaMailSender mailSender;
    // 发件箱(这是一个假的发件箱)
    private static String MAIL_FROM = "test@test.com";
    // 收件箱(这是一个假的收件箱)
    private static String MAIL_TO = "test@test.com";
     * 发送简单邮件
    @RequestMapping("sendSimpleMail")
    public String sendSimpleMail() {
        SimpleMailMessage message = new SimpleMailMessage();
        // 发件箱
        message.setFrom(MAIL_FROM);
        // 收件箱可以是多个,用 String[] 表示多个收件箱
        message.setTo(MAIL_TO);
        // 邮件主题
        message.setSubject("主题:发送简单邮件");
        // 邮件正文
        message.setText("测试简单邮件内容");
        try {
            mailSender.send(message);
            return "success";
        } catch (Exception e) {
            log.error("发送简单邮件异常", e);
            return "failure";
  3.2 发送 HTML 格式的邮件
package com.demo.mail.controller;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.mail.javamail.JavaMailSender;
import org.springframework.mail.javamail.MimeMessageHelper;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import javax.mail.internet.MimeMessage;
@RestController
public class MailController {
    private static Logger log = LoggerFactory.getLogger(MailController.class);
    @Autowired
    private JavaMailSender mailSender;
    // 发件箱(这是一个假的收件箱)
    private static String MAIL_FROM = "test@test.com";
    // 收件箱(这是一个假的收件箱)
    private static String MAIL_TO = "test@test.com";
     * 发送 HTML 格式的邮件
     * @return 邮件发送结果(成功:success;失败:failure)
    @RequestMapping("/sendHtmlMail")
    public String sendHtmlMail() {
        try {
            MimeMessage mimeMessage = mailSender.createMimeMessage();
            MimeMessageHelper helper = new MimeMessageHelper(mimeMessage, true, "UTF-8");
            helper.setFrom(MAIL_FROM);
            helper.setTo(MAIL_TO);
            helper.setSubject("主题:发送 html 内容");
            StringBuffer sb = new StringBuffer();
            sb.append("<h1>大标题</h1>")
                    .append("<p style='color:#F00'>红色字</p >")
                    .append("<p style='text-align:right'>右对齐</p >");
            helper.setText(sb.toString(), true);
            mailSender.send(mimeMessage);
            return "success";
        } catch (Exception e) {
            // 发送 html 邮件失败
            log.error("发送 html 邮件失败", e);
            return "failure";
  3.3 发送带附件的邮件
package com.demo.mail.controller;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.mail.javamail.JavaMailSender;
import org.springframework.mail.javamail.MimeMessageHelper;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import javax.mail.internet.MimeMessage;
import java.io.File;
@RestController
public class MailController {
    private static Logger log = LoggerFactory.getLogger(MailController.class);
    @Autowired
    private JavaMailSender mailSender;
    // 发件箱(这是一个假的收件箱)
    private static String MAIL_FROM = "test@test.com";
    // 收件箱(这是一个假的收件箱)
    private static String MAIL_TO = "test@test.com";
     * 发送带附件的邮件
     * @param file 文件地址及名称,如:/home/testuser/test.txt
     * @return 邮件发送结果(成功:success;失败:failure)
    @RequestMapping("/sendMailWithFile")
    public String sendMailWithFile(String file) {
        try {
            // 设置参数,不允许截断文件名,防止附件名乱码
            System.setProperty("mail.mime.splitlongparameters", "false");
            MimeMessage mimeMessage = mailSender.createMimeMessage();
            MimeMessageHelper messageHelper = new MimeMessageHelper(mimeMessage, true, "UTF-8");
            messageHelper.setFrom(MAIL_FROM);
            messageHelper.setTo(MAIL_TO);
            messageHelper.setText("附件是测试文本,请查收。如有问题请与发件人联系。");
            messageHelper.setSubject("主题:周报测试文本");
            messageHelper.addAttachment("test.txt", new File(file));
            // 附件可以添加多个
            messageHelper.addAttachment("test1.txt", new File(file));
            mailSender.send(mimeMessage);
            return "success";
        } catch (Exception e) {
            // 发送邮件失败
            log.error("发送带附件的邮件失败", e);
            return "failure";
  3.4 发送嵌入静态资源的邮件

  有一种邮件是通过嵌入图片等静态资源,可以在正文中直接看到图片,而不用从附近中查看具体的图片,下面是实现代码。

package com.demo.mail.controller;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.core.io.FileSystemResource;
import org.springframework.mail.javamail.JavaMailSender;
import org.springframework.mail.javamail.MimeMessageHelper;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import javax.mail.internet.MimeMessage;
import java.io.File;
@RestController
public class MailController {
    private static Logger log = LoggerFactory.getLogger(MailController.class);
    @Autowired
    private JavaMailSender mailSender;
    // 发件箱(这是一个假的收件箱)
    private static String MAIL_FROM = "test@test.com";
    // 收件箱(这是一个假的收件箱)
    private static String MAIL_TO = "test@test.com";
     * 发送嵌入静态资源的邮件,正文中可以直接看到图片,而不用从附件中查看具体图片
     * @param imgFile 文件地址及名称,如:/home/testuser/test.png
     * @return 邮件发送结果(成功:success;失败:failure)
    @RequestMapping("/sendResourceMail")
    public String sendResourceMail(String imgFile) {
        try {
            MimeMessage mimeMessage = mailSender.createMimeMessage();
            MimeMessageHelper helper = new MimeMessageHelper(mimeMessage, true, "UTF-8");
            helper.setFrom(MAIL_FROM);
            helper.setTo(MAIL_TO);
            helper.setSubject("主题:发送静态资源邮件");
            helper.setText("<html><body>< img src=\"cid:hello\"></body></html>", true);
            // 注意:addInline() 中的资源名称 hello 必须与 text 正文中 cid:hello 对应起来
            FileSystemResource file = new FileSystemResource(new File(imgFile));
            helper.addInline("hello", file);
            mailSender.send(mimeMessage);
            return "success";
        } catch (Exception e) {
            // 发送嵌入静态资源的邮件失败
            log.error("发送静态资源邮件失败", e);
            return "failure";
复制代码
分类:
后端
标签: