SpringBoot添加Email发送功能及常见异常详解

1、完整的邮件发送代码

1.1、依赖包

<dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-support</artifactId>
      <version>2.0.8</version>
      <exclusions>
        <exclusion>
          <groupId>javax.servlet</groupId>
          <artifactId>servlet-api</artifactId>
        </exclusion>
      </exclusions>
</dependency>
<dependency>
      <groupId>javax.mail</groupId>
      <artifactId>mail</artifactId>
      <version>1.4.7</version>
</dependency>

主要用到了两个jar包:mail-1.4.7.jar、spring-support-2.0.8.jar.

1.2、邮件发送类

package com.autonavi.utils;

import java.util.Properties;

import javax.mail.MessagingException;
import javax.mail.internet.MimeMessage;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.mail.javamail.JavaMailSenderImpl;
import org.springframework.mail.javamail.MimeMessageHelper;

import com.autonavi.constants.Constant;

public class EmailUtils {

  private static final Logger logger = LoggerFactory.getLogger(EmailUtils.class);

  public static boolean sendHtmlMail(String subject,String content,String receiver){

    boolean result = true;

    try{
      JavaMailSenderImpl senderImpl = new JavaMailSenderImpl(); 

      // 设定mail server
      senderImpl.setHost("smtp.abcdefg.com");
      senderImpl.setPort(345);
      senderImpl.setUsername(Constant.email);               // 根据自己的情况,设置发件邮箱地址
      senderImpl.setPassword(Constant.email_password);          // 根据自己的情况, 设置password
      senderImpl.setDefaultEncoding("UTF-8");
      Properties prop = new Properties();
      prop.put("mail.smtp.auth", "true");                 // 将这个参数设为true,让服务器进行认证,认证用户名和密码是否正确
      prop.put("mail.smtp.ssl.enable", "true");
      prop.put("mail.smtp.socketFactory.class", "javax.net.ssl.SSLSocketFactory");
      senderImpl.setJavaMailProperties(prop); 

      // 建立邮件消息,发送简单邮件和html邮件的区别
      MimeMessage mailMessage = senderImpl.createMimeMessage();
      MimeMessageHelper messageHelper = new MimeMessageHelper(mailMessage); 

      // 设置收件人,寄件人
      messageHelper.setTo(receiver);
      messageHelper.setFrom(Constant.email);
      messageHelper.setSubject(subject);
      // true 表示启动HTML格式的邮件
      messageHelper.setText(content,true); 

      // 发送邮件
      senderImpl.send(mailMessage);
    } catch (MessagingException e) {
      // TODO Auto-generated catch block
      result = false;
      logger.info("EmailUtils.method [sendHtmlMail]: email send result-" + result +",error message-" + e);
    }

    return result;
  }

}

以上设置中,有几个点需要注意:

第一点:

senderImpl.setUsername(Constant.email);
senderImpl.setPassword(Constant.email_password); 

上面两个方法是用来设置发件的邮箱,邮箱地址要写全,如aba@abc.com。

如果设置得不对,会提示权限错误。

第二点:

senderImpl.setDefaultEncoding(“UTF-8”); 

这个一定记得设置,否则会邮件发出去会是下面这种结果。

第三点:

Properties prop = new Properties();
prop.put(“mail.smtp.auth”, “true”);
prop.put(“mail.smtp.ssl.enable”, “true”);
prop.put(“mail.smtp.socketFactory.class”, “javax.NET.ssl.SSLSocketFactory”);
senderImpl.setJavaMailProperties(prop); 

一定要记得配置Properties,且上述配置缺一不可,如果没配置,大家会看见各种奇怪的异常。

1.3、邮件正文处理,使用HTML模版

下面的getHtmlStr()方法用来将待发送的内容处理为HTML模版。

public static String getHtmlStr(JSONArray data,String receiver,int day){

    JSONObject json = data.getJSONObject(0);
    String title = json.getString("task_tittle");
    // NO.1、获取收件人名
    String receiverName = getEmailStr(receiver);
    // NO.2、获取邮件表格
    String emailTable = getTableStr(data);
    // NO.3、获取邮件时间
    String emailDate = Date2Str.getCurrentDate2();

    String html = "<html><head></head><body>"
          + "<p>" +receiverName+" 您好,</p>"
          + "<p>    生产日程-<font size=\"4\" color=\"#FF0000\" face=\"Verdana\" >"+title+"</font>中的下列任务将于<font size=\"4\" color=\"#FF0000\" face=\"Verdana\" >"+day+"</font>天后开始启动,请关注:</p>"
          + "<div style=\"padding-left:20px\">"
          + "<table border=\"1px\" cellspacing=\"0px\" style=\"border-collapse:collapse\">"
          + "<tr>"
          + "<td>任务名</td><td>启动时间</td><td>结束时间</td>"
          + "</tr>"
          + emailTable
          + "</table></div>"
          + "<p>    每项任务的详细情况,请登陆 "
          + "<a href=\"http://100.78.205.244:8080\"><font size=\"4\" color=\"#FF0000\">项目综合管理&评价系统</font></a> 查看!</p>"
          + "<p>项目综合管理&评价系统</br>"+emailDate+"</p>"
          + "</body></html>";

    return html;
  }

应用改模版后,发出的邮件显示效果如下:

至于具体业务场景,你想定义什么样的模版都行。

2、常见异常

503异常

2016-04-13-16-48 [scheduler-3] [org.springframework.scheduling.support.TaskUtils$LoggingErrorHandler] [ERROR] - Unexpected error occurred in scheduled task.
 org.springframework.mail.MailSendException; nested exception details (1) are:
Failed message 1:
javax.mail.SendFailedException: Invalid Addresses;
 nested exception is:
  com.sun.mail.smtp.SMTPAddressFailedException: 503 RCPT account isn't a local account

  at com.sun.mail.smtp.SMTPTransport.rcptTo(SMTPTransport.java:1862)
  at com.sun.mail.smtp.SMTPTransport.sendMessage(SMTPTransport.java:1118)
  at org.springframework.mail.javamail.JavaMailSenderImpl.doSend(JavaMailSenderImpl.java:388)
  at org.springframework.mail.javamail.JavaMailSenderImpl.send(JavaMailSenderImpl.java:332)
  at org.springframework.mail.javamail.JavaMailSenderImpl.send(JavaMailSenderImpl.java:328)
  at com.autonavi.utils.EmailUtils.sendHtmlMail(EmailUtils.java:50)
  at com.autonavi.method.gaokuai.IssueForward.action(IssueForward.java:81)
  at com.autonavi.task.ScheduledTasks.executeAutoAssignTask(ScheduledTasks.java:121)
  at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
  at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
  at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
  at java.lang.reflect.Method.invoke(Method.java:606)
  at org.springframework.scheduling.support.ScheduledMethodRunnable.run(ScheduledMethodRunnable.java:65)
  at org.springframework.scheduling.support.DelegatingErrorHandlingRunnable.run(DelegatingErrorHandlingRunnable.java:54)
  at org.springframework.scheduling.concurrent.ReschedulingRunnable.run(ReschedulingRunnable.java:81)
  at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:471)
  at java.util.concurrent.FutureTask.run(FutureTask.java:262)
  at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.access$201(ScheduledThreadPoolExecutor.java:178)
  at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(ScheduledThreadPoolExecutor.java:292)
  at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145)
  at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)
  at java.lang.Thread.run(Thread.java:745)
Caused by: com.sun.mail.smtp.SMTPAddressFailedException: 503 RCPT account isn't a local account

  at com.sun.mail.smtp.SMTPTransport.rcptTo(SMTPTransport.java:1715)
  ... 21 more

如果运行过程中报上述异常,请再次核对收发邮件的邮箱账号是否有效。

3、总结

SpringBoot邮件发送主要是利用已封装好的两个jar包:mail-1.4.7.jar、spring-support-2.0.8.jar,使得配置邮件发送不再复杂。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • SpringBoot初始教程之统一异常处理详解

    1.介绍 在日常开发中发生了异常,往往是需要通过一个统一的异常处理处理所有异常,来保证客户端能够收到友好的提示.SpringBoot在页面发生异常的时候会自动把请求转到/error,SpringBoot内置了一个BasicErrorController对异常进行统一的处理,当然也可以自定义这个路径 application.yaml server: port: 8080 error: path: /custom/error BasicErrorController提供两种返回错误一种是页面返回.当

  • 浅谈spring boot 1.5.4 异常控制

    spring boot 已经做了统一的异常处理,下面看看如何自定义处理异常 1.错误码页面映射 1.1静态页面 必须配置在 resources/static/error文件夹下,以错误码命名 下面是404错误页面内容,当访问一个不存在的链接的时候,定位到此页 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Not F

  • 详解Springboot自定义异常处理

    背景 Springboot 默认把异常的处理集中到一个ModelAndView中了,但项目的实际过程中,这样做,并不能满足我们的要求.具体的自定义异常的处理,参看以下 具体实现 如果仔细看完spring boot的异常处理详解,并且研究过源码后,我觉得具体的实现可以不用看了... 重写定义错误页面的url,默认只有一个/error @Bean public EmbeddedServletContainerCustomizer containerCustomizer(){ return new E

  • springboot全局异常处理详解

    一.单个controller范围的异常处理 package com.xxx.secondboot.web; import org.springframework.web.bind.annotation.ExceptionHandler; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestMethod; import

  • 浅谈Spring Boot 异常处理篇

    前言 先谈谈"异常处理"这件事.下面有 2 份伪代码,对比下: // ① 基于 if/else 判断 if(deletePage(page) == E_OK){ if(registry.deleteReference(page.name) == E_OK){ if(configKeys.deleteKey(page.name.makeKey()) == E_OK){ logger.log("page deleted"); }else{ logger.log(&quo

  • Spring Boot全局异常处理解析

    本文为大家分享了Spring Boot全局异常处理,供大家参考,具体内容如下 1.后台处理异常 a.引入thymeleaf依赖 <!-- thymeleaf模板插件 --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-thymeleaf</artifactId> </dependency>

  • spring boot请求异常处理并返回对应的html页面

    通过之前的学习,我知道中间件可以预处理http请求并返回相应页面(比如出现404异常,可以返回一个自己编写的异常界面,而非默认使用的白板404页面,很难看).其实spring boot也提供了这样的功能. 404异常处理: @Controller public class ErrorHandler404 implements ErrorController { private static final String ERROR_PATH = "/error"; @RequestMapp

  • springboot springmvc抛出全局异常的解决方法

    springboot中抛出异常,springboot自带的是springmvc框架,这个就不多说了. springmvc统一异常解决方法这里要说明的是.只是结合了springboot的使用而已.直接上代码,有效有用的才是ok. 1.定义异常捕获 package com.example.rest.error; import org.springframework.http.HttpStatus; import org.springframework.web.bind.annotation.Exce

  • Spring Boot统一异常处理详解

    Spring Boot中默认带了error的映射,但是这个错误页面显示给用户并不是很友好. 统一异常处理 通过使用@ControllerAdvice定义统一异常处理的类,而不是在每个Controller中逐个定义. @ExceptionHandler用来定义函数针对的函数类型,最后将Exception对象和请求URL映射到URL中. @ControllerAdvice class ExceptionTranslator { public static final String DEFAULT_E

  • Spring Boot学习入门之统一异常处理详解

    前言 关于之前的一篇所讲到的表单验证中提到,如果产生错误,可以得到错误的信息,但是返回值的问题却没有考虑. 其中所提到的Controller: @RequestMapping(value = "/doRegister", method = RequestMethod.POST) public @ResponseBody User doRegister(@Valid User user, BindingResult result, Model model) { if (result.ha

随机推荐