整合營銷服務商

          電腦端+手機端+微信端=數據同步管理

          免費咨詢熱線:

          10 分鐘實現 Java 發送郵件功能


          pring Boot集成郵件服務竟如此簡單,快速掌握郵件業務類的核心邏輯和企業郵件的日常服務。


          什么是SMTP?


          SMTP全稱為Simple Mail Transfer Protocol(簡單郵件傳輸協議),它是一組用于從源地址到目的地址傳輸郵件的規范,通過它來控制郵件的中轉方式。SMTP認證要求必須提供賬號和密碼才能登陸服務器,其設計目的在于避免用戶受到垃圾郵件的侵擾。


          什么是IMAP?


          IMAP全稱為Internet Message Access Protocol(互聯網郵件訪問協議),IMAP允許從郵件服務器上獲取郵件的信息、下載郵件等。IMAP與POP類似,都是一種郵件獲取協議。


          什么是POP3?


          POP3全稱為Post Office Protocol 3(郵局協議),POP3支持客戶端遠程管理服務器端的郵件。POP3常用于“離線”郵件處理,即允許客戶端下載服務器郵件,然后服務器上的郵件將會被刪除。目前很多POP3的郵件服務器只提供下載郵件功能,服務器本身并不刪除郵件,這種屬于改進版的POP3協議。


          IMAP和POP3協議有什么不同呢?


          兩者最大的區別在于,IMAP允許雙向通信,即在客戶端的操作會反饋到服務器上,例如在客戶端收取郵件、標記已讀等操作,服務器會跟著同步這些操作。而對于POP協議雖然也允許客戶端下載服務器郵件,但是在客戶端的操作并不會同步到服務器上面的,例如在客戶端收取或標記已讀郵件,服務器不會同步這些操作。


          什么是JavaMailSender和JavaMailSenderImpl?


          JavaMailSender和JavaMailSenderImpl 是Spring官方提供的集成郵件服務的接口和實現類,以簡單高效的設計著稱,目前是Java后端發送郵件和集成郵件服務的主流工具。


          如何通過JavaMailSenderImpl發送郵件?


          非常簡單,直接在業務類注入JavaMailSenderImpl并調用send方法發送郵件。其中簡單郵件可以通過SimpleMailMessage來發送郵件,而復雜的郵件(例如添加附件)可以借助MimeMessageHelper來構建MimeMessage發送郵件。例如:


          @Autowired
              private JavaMailSenderImpl mailSender;
          
              public void sendMail() throws MessagingException {
                  
                  SimpleMailMessage simpleMailMessage = new SimpleMailMessage();
                  simpleMailMessage.setFrom("admin@163.com");
                  simpleMailMessage.setTo("socks@qq.com");
                  simpleMailMessage.setSubject("Happy New Year");
                  simpleMailMessage.setText("新年快樂!");
                  mailSender.send(simpleMailMessage);
          
                  
                  MimeMessage mimeMessage = mailSender.createMimeMessage();
                  MimeMessageHelper messageHelper = new MimeMessageHelper(mimeMessage);
                  messageHelper.setFrom("admin@163.com");
                  messageHelper.setTo("socks@qq.com");
                  messageHelper.setSubject("Happy New Year");
                  messageHelper.setText("新年快樂!");
                  messageHelper.addInline("doge.gif", new File("xx/xx/doge.gif"));
                  messageHelper.addAttachment("work.docx", new File("xx/xx/work.docx"));
                  mailSender.send(mimeMessage);
              }為什么JavaMailSenderImpl 能夠開箱即用 ?

          所謂開箱即用其實就是基于官方內置的自動配置,翻看源碼可知曉郵件自動配置類(MailSenderPropertiesConfiguration) 為上下文提供了郵件服務實例(JavaMailSenderImpl)。具體源碼如下:


          @Configuration
          @ConditionalOnProperty(prefix = "spring.mail", name = "host")
          class MailSenderPropertiesConfiguration {
              private final MailProperties properties;
              MailSenderPropertiesConfiguration(MailProperties properties) {
                  this.properties = properties;
              }
              @Bean
              @ConditionalOnMissingBean
              public JavaMailSenderImpl mailSender() {
                  JavaMailSenderImpl sender = new JavaMailSenderImpl();
                  applyProperties(sender);
                  return sender;
              }


          其中MailProperties是關于郵件服務器的配置信息,具體源碼如下:


          @ConfigurationProperties(prefix = "spring.mail")
          public class MailProperties {
              private static final Charset DEFAULT_CHARSET = StandardCharsets.UTF_8;
              private String host;
              private Integer port;
              private String username;
              private String password;
              private String protocol = "smtp";
              private Charset defaultEncoding = DEFAULT_CHARSET;
              private Map<String, String> properties = new HashMap<>();
          }



          一、開啟郵件服務


          登陸網易郵箱163,在設置中打開并勾選POP3/SMTP/IMAP服務,然后會得到一個授權碼,這個郵箱和授權碼將用作登陸認證。



          二、配置郵件服務首先咱們通過 Spring Initializr 創建工程

          springboot-send-mail,如圖所示:



          然后在pom.xml 引入web、thymeleaf 和spring-boot-starter-mail等相關依賴。例如:


          <dependencies>
                  <dependency>
                      <groupId>org.springframework.bootgroupId>
                      <artifactId>spring-boot-starter-webartifactId>
                  dependency>
                  <dependency>
                      <groupId>org.springframework.bootgroupId>
                      <artifactId>spring-boot-starter-thymeleafartifactId>
                  dependency>
                  <dependency>
                      <groupId>org.springframework.bootgroupId>
                      <artifactId>spring-boot-starter-mailartifactId>
                  dependency>
                  <dependency>
                      <groupId>org.webjarsgroupId>
                      <artifactId>webjars-locator-coreartifactId>
                  dependency>
                  <dependency>
                      <groupId>org.webjarsgroupId>
                      <artifactId>jqueryartifactId>
                      <version>3.3.1version>
                  dependency>
                  <dependency>
                      <groupId>org.webjarsgroupId>
                      <artifactId>bootstrapartifactId>
                      <version>3.3.7version>
                  dependency>
                  <dependency>
                      <groupId>org.springframework.bootgroupId>
                      <artifactId>spring-boot-devtoolsartifactId>
                      <scope>runtimescope>
                  dependency>
                  <dependency>
                      <groupId>org.springframework.bootgroupId>
                      <artifactId>spring-boot-starter-testartifactId>
                      <scope>testscope>
                  dependency>
              dependencies>


          根據前面提到的配置項(MailProperties)填寫相關配置信息,其中spring.mail.username 表示連接郵件服務器時認證的登陸賬號,可以是普通的手機號或者登陸賬號,并非一定是郵箱,為了解決這個問題,推薦大家在spring.mail. properties.from填寫郵件發信人即真實郵箱。


          然后在application.yml添加如下配置:


          spring:
            mail:
              host: smtp.163.com #SMTP服務器地址
              username: socks #登陸賬號
              password: 123456 #登陸密碼(或授權碼)
              properties:
                from: socks@163.com #郵件發信人(即真實郵箱)
            thymeleaf:
              cache: false
              prefix: classpath:/views/
            servlet:
              multipart:
                max-file-size: 10MB #限制單個文件大小
                max-request-size: 50MB #限制請求總量


          透過前面的進階知識,我們知道在發送郵件前,需要先構建SimpleMailMessage或 MimeMessage 郵件信息類來填寫郵件標題、郵件內容等信息,最后提交給JavaMailSenderImpl發送郵件,這樣看起來沒什么問題,也能實現既定目標,但在實際使用中會出現大量零散和重復的代碼,還不便于保存郵件到數據庫。


          那么優雅的發送郵件應該是如何的呢?應該屏蔽掉這些構建信息和發送郵件的細節,不管是簡單還是復雜郵件,都可以通過統一的API來發送郵件。例如:mailService.send(mailVo) 。例如通過郵件信息類(MailVo) 來保存發送郵件時的郵件主題、郵件內容等信息 :


          package com.hehe.vo;
          
          public class MailVo {
              private String id;
              private String from;
              private String to;
              private String subject;
              private String text;
              private Date sentDate;
              private String cc;
              private String bcc;
              private String status;
              private String error;
              @JsonIgnore
              private MultipartFile[] multipartFiles;
             
          }



          三、發送郵件和附件


          除了發送郵件之外,還包括檢測郵件和保存郵件等操作,例如:


          • 檢測郵件 checkMail(); 首先校驗郵件收信人、郵件主題和郵件內容這些必填項,若為空則拒絕發送。
          • 發送郵件 sendMimeMail(); 其次通過MimeMessageHelper來解析MailVo并構建MimeMessage傳輸郵件。
          • 保存郵件 sendMimeMail(); 最后將郵件保存到數據庫,便于統計和追查郵件問題。


          本案例郵件業務類 MailService 的具體源碼如下:


          package com.hehe.service;
          
          
          @Service
          public class MailService {
          
              private Logger logger = LoggerFactory.getLogger(getClass());
          
              @Autowired
              private JavaMailSenderImpl mailSender;
          
          
              
              public MailVo sendMail(MailVo mailVo) {
                  try {
                      checkMail(mailVo);
                      sendMimeMail(mailVo);
                      return saveMail(mailVo);
                  } catch (Exception e) {
                      logger.error("發送郵件失敗:", e);
                      mailVo.setStatus("fail");
                      mailVo.setError(e.getMessage());
                      return mailVo;
                  }
          
              }
          
              
              private void checkMail(MailVo mailVo) {
                  if (StringUtils.isEmpty(mailVo.getTo())) {
                      throw new RuntimeException("郵件收信人不能為空");
                  }
                  if (StringUtils.isEmpty(mailVo.getSubject())) {
                      throw new RuntimeException("郵件主題不能為空");
                  }
                  if (StringUtils.isEmpty(mailVo.getText())) {
                      throw new RuntimeException("郵件內容不能為空");
                  }
              }
          
              
              private void sendMimeMail(MailVo mailVo) {
                  try {
                      MimeMessageHelper messageHelper = new MimeMessageHelper(mailSender.createMimeMessage(), true);
                      mailVo.setFrom(getMailSendFrom());
                      messageHelper.setFrom(mailVo.getFrom());
                      messageHelper.setTo(mailVo.getTo().split(","));
                      messageHelper.setSubject(mailVo.getSubject());
                      messageHelper.setText(mailVo.getText());
                      if (!StringUtils.isEmpty(mailVo.getCc())) {
                          messageHelper.setCc(mailVo.getCc().split(","));
                      }
                      if (!StringUtils.isEmpty(mailVo.getBcc())) {
                          messageHelper.setCc(mailVo.getBcc().split(","));
                      }
                      if (mailVo.getMultipartFiles() != null) {
                          for (MultipartFile multipartFile : mailVo.getMultipartFiles()) {
                              messageHelper.addAttachment(multipartFile.getOriginalFilename(), multipartFile);
                          }
                      }
                      if (StringUtils.isEmpty(mailVo.getSentDate())) {
                          mailVo.setSentDate(new Date());
                          messageHelper.setSentDate(mailVo.getSentDate());
                      }
                      mailSender.send(messageHelper.getMimeMessage());
                      mailVo.setStatus("ok");
                      logger.info("發送郵件成功:{}->{}", mailVo.getFrom(), mailVo.getTo());
                  } catch (Exception e) {
                      throw new RuntimeException(e);
                  }
              }
          
              
              private MailVo saveMail(MailVo mailVo) {
                  
                  return mailVo;
              }
          
              
              public String getMailSendFrom() {
                  return mailSender.getJavaMailProperties().getProperty("from");
              }
          }


          搞定了發送郵件最核心的業務邏輯,接下來咱們寫一個簡單頁面用來發送郵件。


          首先寫好跟頁面交互的控制器 MailController,具體源碼如下:


          @RestController
          public class MailController {
              @Autowired
              private MailService mailService;
          
              
              @GetMapping("/")
              public ModelAndView index() {
                  ModelAndView mv = new ModelAndView("mail/sendMail");
                  mv.addObject("from", mailService.getMailSendFrom());
                  return mv;
              }
              
              @PostMapping("/mail/send")
              public MailVo sendMail(MailVo mailVo, MultipartFile[] files) {
                  mailVo.setMultipartFiles(files);
                  return mailService.sendMail(mailVo);
              }
          }


          然后在/resources/views/mail目錄新建sendMail.html,具體源碼如下:


          
          <html xmlns:th="http://www.thymeleaf.org">
          
          <head>
              <meta charset="UTF-8"/>
              <title>發送郵件title>
              <link th:href="@{/webjars/bootstrap/css/bootstrap.min.css}" rel="stylesheet" type="text/css"/>
              <script th:src="@{/webjars/jquery/jquery.min.js}">script>
              <script th:href="@{/webjars/bootstrap/js/bootstrap.min.js}">script>
          
          head>
          
          <body>
          <div class="col-md-6" style="margin:20px;padding:20px;border: #E0E0E0 1px solid;">
              <marquee behavior="alternate" onfinish="alert(12)" id="mq"
                       onMouseOut="this.start();$('#egg').text('嗯 真聽話!');"
                       onMouseOver="this.stop();$('#egg').text('有本事放開我呀!');">
                  <h5 id="egg">祝大家新年快樂!h5><img id="doge" src="http://pics.sc.chinaz.com/Files/pic/faces/3709/7.gif" alt="">
              marquee>
          
              <form class="form-horizontal" id="mailForm">
                  <div class="form-group">
                      <label class="col-md-2 control-label">郵件發信人:label>
                      <div class="col-md-6">
                          <input class="form-control" id="from" name="from" th:value="${from}" readonly="readonly">
                      div>
                  div>
                  <div class="form-group">
                      <label class="col-md-2 control-label">郵件收信人:label>
                      <div class="col-md-6">
                          <input class="form-control" id="to" name="to" title="多個郵箱使用,隔開">
                      div>
                  div>
                  <div class="form-group">
                      <label class="col-md-2 control-label">郵件主題:label>
                      <div class="col-md-6">
                          <input class="form-control" id="subject" name="subject">
                      div>
                  div>
                  <div class="form-group">
                      <label class="col-md-2 control-label">郵件內容:label>
                      <div class="col-md-6">
                          <textarea class="form-control" id="text" name="text" rows="5">textarea>
                      div>
                  div>
                  <div class="form-group">
                      <label class="col-md-2 control-label">郵件附件:label>
                      <div class="col-md-6">
                          <input class="form-control" id="files" name="files" type="file" multiple="multiple">
                      div>
                  div>
                  <div class="form-group">
                      <label class="col-md-2 control-label">郵件操作:label>
                      <div class="col-md-3">
                          <a class="form-control btn btn-primary" onclick="sendMail()">發送郵件a>
                      div>
                      <div class="col-md-3">
                          <a class="form-control btn btn-default" onclick="clearForm()">清空a>
                      div>
                  div>
              form>
          
              <script th:inline="javascript">
                  var appCtx = [[${#request.getContextPath()}]];
          
                  function sendMail() {
          
                      var formData = new FormData($('#mailForm')[0]);
                      $.ajax({
                          url: appCtx + '/mail/send',
                          type: "POST",
                          data: formData,
                          contentType: false,
                          processData: false,
                          success: function (result) {
                              alert(result.status === 'ok' ? "發送成功!" : "你被Doge嘲諷了:" + result.error);
                          },
                          error: function () {
                              alert("發送失敗!");
                          }
                      });
                  }
          
                  function clearForm() {
                      $('#mailForm')[0].reset();
                  }
          
                  setInterval(function () {
                      var total = $('#mq').width();
                      var width = $('#doge').width();
                      var left = $('#doge').offset().left;
                      if (left <= width / 2 + 20) {
                          $('#doge').css('transform', 'rotateY(180deg)')
                      }
                      if (left >= total - width / 2 - 40) {
                          $('#doge').css('transform', 'rotateY(-360deg)')
                      }
                  });
              script>
          div>
          body>
          html>



          四、測試發送郵件


          如果是初學者,建議大家先下載源碼,修改配置后運行工程,成功后再自己重新寫一遍代碼,這樣有助于加深記憶。


          啟動工程并訪問:http://localhost:8080 然后可以看到發送郵件的主界面如下:



          然后填寫你的小號郵箱,點擊發送郵件,若成功則可以登陸小號郵箱查看郵件和剛才上傳的附件。



          至此發送郵件代碼全部完成,歡迎大家下載并關注Github 源碼。


          五、常見失敗編碼


          如果企業定制了郵件服務器,自然會記錄郵件日志,根據錯誤編碼存儲日志有利于日常維護。例如這些由網易郵箱提供的錯誤編碼標識:421421 HL:REP 該IP發送行為異常,存在接收者大量不存在情況,被臨時禁止連接。請檢查是否有用戶發送病毒或者垃圾郵件,并核對發送列表有效性;


          421 HL:ICC 該IP同時并發連接數過大,超過了網易的限制,被臨時禁止連接。請檢查是否有用戶發送病毒或者垃圾郵件,并降低IP并發連接數量;


          421 HL:IFC 該IP短期內發送了大量信件,超過了網易的限制,被臨時禁止連接。請檢查是否有用戶發送病毒或者垃圾郵件,并降低發送頻率;


          421 HL:MEP 該IP發送行為異常,存在大量偽造發送域域名行為,被臨時禁止連接。請檢查是否有用戶發送病毒或者垃圾郵件,并使用真實有效的域名發送;


          450450 MI:CEL 發送方出現過多的錯誤指令。請檢查發信程序;


          450 MI:DMC 當前連接發送的郵件數量超出限制。請減少每次連接中投遞的郵件數量;


          450 MI:CCL 發送方發送超出正常的指令數量。請檢查發信程序;


          450 RP:DRC 當前連接發送的收件人數量超出限制。請控制每次連接投遞的郵件數量;


          450 RP:CCL 發送方發送超出正常的指令數量。請檢查發信程序;


          450 DT:RBL 發信IP位于一個或多個RBL里。請參考

          http://www.rbls.org/關于RBL的相關信息;


          450 WM:BLI 該IP不在網易允許的發送地址列表里;


          450 WM:BLU 此用戶不在網易允許的發信用戶列表里;451451 DT:SPM ,please try again 郵件正文帶有垃圾郵件特征或發送環境缺乏規范性,被臨時拒收。請保持郵件隊列,兩分鐘后重投郵件。需調整郵件內容或優化發送環境;


          451 Requested mail action not taken: too much fail authentication 登錄失敗次數過多,被臨時禁止登錄。請檢查密碼與帳號驗證設置;


          451 RP:CEL 發送方出現過多的錯誤指令。請檢查發信程序;


          451 MI:DMC 當前連接發送的郵件數量超出限制。請控制每次連接中投遞的郵件數量;


          451 MI:SFQ 發信人在15分鐘內的發信數量超過限制,請控制發信頻率;


          451 RP:QRC 發信方短期內累計的收件人數量超過限制,該發件人被臨時禁止發信。請降低該用戶發信頻率;


          451 Requested action aborted: local error in processing 系統暫時出現故障,請稍后再次嘗試發送;500500 Error: bad syntaxU 發送的smtp命令語法有誤;


          550 MI:NHD HELO命令不允許為空;


          550 MI:IMF 發信人電子郵件地址不合規范。請參考http://www.rfc-editor.org/關于電子郵件規范的定義;


          550 MI:SPF 發信IP未被發送域的SPF許可。請參考http://www.openspf.org/關于SPF規范的定義;


          550 MI:DMA 該郵件未被發信域的DMARC許可。請參考http://dmarc.org/關于DMARC規范的定義;


          550 MI:STC 發件人當天的連接數量超出了限定數量,當天不再接受該發件人的郵件。請控制連接次數;


          550 RP:FRL 網易郵箱不開放匿名轉發(Open relay);


          550 RP:RCL 群發收件人數量超過了限額,請減少每封郵件的收件人數量;


          550 RP:TRC 發件人當天內累計的收件人數量超過限制,當天不再接受該發件人的郵件。請降低該用戶發信頻率;


          550 DT:SPM 郵件正文帶有很多垃圾郵件特征或發送環境缺乏規范性。需調整郵件內容或優化發送環境;


          550 Invalid User 請求的用戶不存在;


          550 User in blacklist 該用戶不被允許給網易用戶發信;


          550 User suspended 請求的用戶處于禁用或者凍結狀態;


          550 Requested mail action not taken: too much recipient 群發數量超過了限額;552552 Illegal Attachment 不允許發送該類型的附件,包括以.uu .pif .scr .mim .hqx .bhx .cmd .vbs .bat .com .vbe .vb .js .wsh等結尾的附件;


          552 Requested mail action aborted: exceeded mailsize limit 發送的信件大小超過了網易郵箱允許接收的最大限制;553553 Requested action not taken: NULL sender is not allowed 不允許發件人為空,請使用真實發件人發送;


          553 Requested action not taken: Local user only SMTP類型的機器只允許發信人是本站用戶;


          553 Requested action not taken: no smtp MX only MX類型的機器不允許發信人是本站用戶;


          553 authentication is required SMTP需要身份驗證,請檢查客戶端設置;554554 DT:SPM 發送的郵件內容包含了未被許可的信息,或被系統識別為垃圾郵件。請檢查是否有用戶發送病毒或者垃圾郵件;


          554 DT:SUM 信封發件人和信頭發件人不匹配;


          554 IP is rejected, smtp auth error limit exceed 該IP驗證失敗次數過多,被臨時禁止連接。請檢查驗證信息設置;


          554 HL:IHU 發信IP因發送垃圾郵件或存在異常的連接行為,被暫時掛起。請檢測發信IP在歷史上的發信情況和發信程序是否存在異常;


          554 HL:IPB 該IP不在網易允許的發送地址列表里;


          554 MI:STC 發件人當天內累計郵件數量超過限制,當天不再接受該發件人的投信。請降低發信頻率;


          554 MI:SPB 此用戶不在網易允許的發信用戶列表里;


          554 IP in blacklist 該IP不在網易允許的發送地址列表里。


          有任何問題私信小編!

          pringBoot整合了Java Mail可以很方便的發送電子郵件。

          我們來看看如何發送HTML格式的電子郵件。

          導入郵件依賴

          在SpringBoot的pom文件中導入電子郵件的starter。

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

          配置郵件信息

          在application.properties中配置郵箱信息,包括郵件服務器地址、用戶名和密碼。

          spring.mail.host=smtp.qq.com
          spring.mail.username=123@qq.com
          spring.mail.password=456

          注入郵件發送器

          使用@Autowired注解注入JavaMailSender對象。

          @Autowired
          private JavaMailSender javaMailSender;

          4.構造HTML郵件

          創建mimeMessage對象發送HTML郵件。

          MimeMessage mimeMessage = javaMailSender.createMimeMessage();
          MimeMessageHelper helper = new MimeMessageHelper(mimeMessage);
          
          try {
              helper.setFrom("123@qq.com(帥鍋)");
              helper.setTo("456@qq.com");
              helper.setSubject("你好");
              helper.setText("<a href='https://www.qq.com'>點我</a>",true);
          } catch (MessagingException e) {
              e.printStackTrace();
          }

          通過MimeMessageHelper對象設置郵件信息。

          setText第一個參數是郵件的正文,在這里輸入HTML代碼

          setText第二個參數是設置是否是HTML郵件,要設置為true

          方法

          作用

          helper.setFrom

          設置發件人地址,可以通過“()”設置別名

          helper.setTo

          設置收件人地址

          helper.setSubject

          設置郵件標題

          helper.setText

          設置郵件正文,第二個參數設置是否為HTML郵件

          發送郵件

          通過 javaMailSender.send方法發送電子郵件,參數是構建的mimeMessage對象。

          @Component
          public class MailServiceImpl implements MailService{
          
              @Autowired
              private JavaMailSender javaMailSender;
          
              @Override
              public void sendMail() {
                  MimeMessage mimeMessage = javaMailSender.createMimeMessage();
                  MimeMessageHelper helper = new MimeMessageHelper(mimeMessage);
          
                  try {
                      helper.setFrom("123@qq.com(帥鍋)");
                      helper.setTo("456@qq.com");
                      helper.setSubject("你好");
                      helper.setText("<a href='https://www.qq.com'>點我</a>",true);
                  } catch (MessagingException e) {
                      e.printStackTrace();
                  }
          
                  javaMailSender.send(mimeMessage);
              }
          }

          測試

          通過測試方法測試郵件發送。

          @SpringBootTest
          public class MailTest {
          
              @Autowired
              private MailService mailService;
          
              @Test
              void test(){
                  mailService.sendMail();
              }
          }

          郵箱收到了發送的郵件,連接是可以點擊的,是一個HTML格式的郵件。

          avaMailSender是Spring Framework提供的一個接口,是Spring框架中用于發送電子郵件的核心接口,主要的作用就是用來簡化郵件在SpringBoot項目中的郵件發送的過程。它是基于JavaMail API封裝了一些常用的功能,使得開發者在SpringBoot項目中發送郵件信息變得高效快捷。

          下面我們就來看看在SpringBoot中如何使用JavaMailSender來發送郵件。

          添加配置

          JavaMailSender接口由Spring Boot的spring-boot-starter-mail模塊提供實現。所以需要添加相關的POM依賴如下所示。

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

          配置郵件服務器

          在application.properties配置文件中添加郵件服務器信息配置,這個郵件服務器的相關信息,我們可以通過查找對應的郵件服務操作來找到。

          spring.mail.host=smtp.gmail.com
          spring.mail.port=587
          spring.mail.username=email@163.com
          spring.mail.password=-password
          spring.mail.properties.mail.smtp.auth=true
          spring.mail.properties.mail.smtp.starttls.enable=true

          創建配置類

          當然除了通過上面的配置文件的方式來進行郵件發送服務的配置之外,我們還可以通過在SpringBoot中添加配置類的方式來對JavaMailSender的相關配置屬性進行設置,如下所示。

          @Configuration
          public class MailConfig {
          
              @Bean
              public JavaMailSender getJavaMailSender() {
                  JavaMailSenderImpl mailSender = new JavaMailSenderImpl();
                  mailSender.setHost("smtp.gmail.com");
                  mailSender.setPort(587);
          
                  mailSender.setUsername("your-email@163.com");
                  mailSender.setPassword("email-password");
          
                  Properties props = mailSender.getJavaMailProperties();
                  props.put("mail.transport.protocol", "smtp");
                  props.put("mail.smtp.auth", "true");
                  props.put("mail.smtp.starttls.enable", "true");
                  props.put("mail.debug", "true");
          
                  return mailSender;
              }
          }
          

          創建郵件服務類

          創建一個名為EmailService的類,用來進行郵件的發送操作,方便在Controller層進行調用。如下所示。

          @Service
          public class EmailService {
          
              @Autowired
              private JavaMailSender mailSender;
          
              public void sendSimpleEmail(String to, String subject, String text) {
                  SimpleMailMessage message = new SimpleMailMessage();
                  message.setTo(to);
                  message.setSubject(subject);
                  message.setText(text);
                  message.setFrom("email@163.com");
          
                  mailSender.send(message);
              }
          }

          在這個服務中指定了郵件的發送者、發送主題、發送的內容、以及發送的有郵箱等信息。接下來我們就來看看如何調用這個郵件發送服務。

          使用郵件服務類發送郵件

          在控制器類或其他服務類中注入這個郵件發送服務并且調用發送郵件的方法來進行郵件的發送操作。

          @RestController
          public class EmailController {
          
              @Autowired
              private EmailService emailService;
          
              @GetMapping("/sendEmail")
              public String sendEmail(@RequestParam String to, @RequestParam String subject, @RequestParam String text) {
                  emailService.sendSimpleEmail(to, subject, text);
                  return "Email sent successfully";
              }
          }

          我們可以通過訪問http://localhost:8080/sendEmail?to=recipient@example.com&subject=Test&text=Hello的URL來發送測試郵件。

          發送復雜郵件

          當然這個郵件只是一個簡單的文字類的郵件,如果我們想要發送更加復雜的收郵件的話可以修改郵件發送的方法,如下所示。

          mport org.springframework.mail.javamail.MimeMessageHelper;
          import org.springframework.mail.javamail.MimeMessagePreparator;
          
          public void sendMimeEmail(String to, String subject, String htmlContent) {
              MimeMessagePreparator preparator = mimeMessage -> {
                  MimeMessageHelper messageHelper = new MimeMessageHelper(mimeMessage, true);
                  messageHelper.setTo(to);
                  messageHelper.setSubject(subject);
                  messageHelper.setText(htmlContent, true);
                  messageHelper.setFrom("email@163.com");
              };
          
              mailSender.send(preparator);
          }
          

          使用MimeMessage,來發送帶有HTML內容或附件的郵件,下面這個展示了如何發送一個帶有附件的郵件。

          import org.springframework.core.io.FileSystemResource;
          
          public void sendEmailWithAttachment(String to, String subject, String text, String pathToAttachment) {
              MimeMessagePreparator preparator = mimeMessage -> {
                  MimeMessageHelper messageHelper = new MimeMessageHelper(mimeMessage, true);
                  messageHelper.setTo(to);
                  messageHelper.setSubject(subject);
                  messageHelper.setText(text);
                  messageHelper.setFrom("your-email@gmail.com");
          
                  FileSystemResource file = new FileSystemResource(pathToAttachment);
                  messageHelper.addAttachment(file.getFilename(), file);
              };
          
              mailSender.send(preparator);
          }

          注意

          在實現郵件發送功能的時候要保證郵件配置的有效性,而對于如何找到上面的郵件配置,有興趣的讀者可以上網進行搜索,基本上所有整合的方式都有,這里提供的是一個思路演示,但是代碼都是有效代碼。

          其次要進行復雜郵件內容發送的時候,一定要注意對郵件中包含的內容進行校驗避免出現跨站腳本攻擊、SQL注入、文件上傳等方面的漏洞保證系統的安全性。

          總結

          JavaMailSender使得在Spring應用中發送郵件變得簡單和高效。通過配置郵件服務器、創建郵件服務類,并調用相應的方法,可以方便地發送各種類型的郵件。


          主站蜘蛛池模板: 精品无码综合一区| 国产日韩精品一区二区三区| 日本精品啪啪一区二区三区| 国产在线一区二区三区av| 亚洲一区二区三区香蕉| 精品人妻AV一区二区三区 | 日韩在线一区视频| 国产精品伦一区二区三级视频| 国模视频一区二区| 狠狠色综合一区二区| 午夜福利av无码一区二区 | 人妻无码一区二区三区| 国精产品999一区二区三区有限| 国产色综合一区二区三区| 日韩精品一区二区三区影院| 精产国品一区二区三产区| 无码人妻精品一区二区三区久久 | 手机看片一区二区| 在线视频国产一区| 国产成人精品久久一区二区三区 | 国产一区在线电影| av无码免费一区二区三区| 日韩精品无码一区二区三区| 国产视频一区二区在线播放| 成人免费一区二区三区| 亚洲AⅤ无码一区二区三区在线| 精品一区二区久久久久久久网精| 精品深夜AV无码一区二区老年| 另类一区二区三区| 亚洲熟妇av一区二区三区漫画| 蜜桃视频一区二区| 麻豆视频一区二区三区| 精品无码中出一区二区| 国产激情一区二区三区在线观看| 无码国产精品一区二区免费式直播| 亚洲AV综合色区无码一区 | 久久一区二区三区免费播放| 久久99国产精品一区二区| 亚洲啪啪综合AV一区| 国产一区二区福利| 亚洲AV无码第一区二区三区|