基于SSM框架+Javamail发送邮件的代码实例

 更新时间:2016年12月27日 08:54:00   作者:u014427391  
本篇文章主要介绍了基于SSM框架+Javamail发送邮件的代码实例,具有一定的参考价值,感兴趣的小伙伴们可以参考一下。

本篇介绍基于SSM框架(Spring4.0+SpringMVC+Mybatis)组合的Javamail应用,邮箱的话基于腾讯的QQ邮箱,其实也是Foxmail邮箱

先要了解一下SMTP协议和SSL加密

SMTP:称为简单邮件传输协议(Simple Mail Transfer Protocal),目标是向用户提供高效、可靠的邮件传输。SMTP是一种请求响应的协议,也就是客户机向远程服务器发送请求,服务器响应,监听端口是25,所以其工作模式有两种:发送SMTP,接收SMTP。

SSL加密:用来保障浏览器和网站服务器的安全性,其原理用译文解释就是:

当你的浏览器向服务器请求一个安全的网页(通常是 https://)

服务器就把它的证书和公匙发回来

浏览器检查证书是不是由可以信赖的机构颁发的,确认证书有效和此证书是此网站的。

使用公钥加密了一个随机对称密钥,包括加密的URL一起发送到服务器

服务器用自己的私匙解密了你发送的钥匙。然后用这把对称加密的钥匙给你请求的URL链接解密。

服务器用你发的对称钥匙给你请求的网页加密。你也有相同的钥匙就可以解密发回来的网页了

然后介绍怎么实现javamail发送邮件,先要下载javamail的jar:http://xiazai.jb51.net/201612/yuanma/mail_jb51.jar

去充当服务器的QQ邮箱开启SMTP服务:

写个发送邮件的业务类:

package com.appms.email;

import java.util.Date;
import java.util.Properties;

import javax.mail.Address;
import javax.mail.Message;
import javax.mail.Session;
import javax.mail.Transport;
import javax.mail.internet.InternetAddress;
import javax.mail.internet.MimeMessage;

import com.sun.mail.util.MailSSLSocketFactory;

public class JavaEmailSender {


  public static void sendEmail(String toEmailAddress,String emailTitle,String emailContent)throws Exception{
    Properties props = new Properties();

    // 开启debug调试
    props.setProperty("mail.debug", "true");
    // 发送服务器需要身份验证
    props.setProperty("mail.smtp.auth", "true");
    // 设置邮件服务器主机名
    props.setProperty("mail.host", "smtp.qq.com");
    // 发送邮件协议名称
    props.setProperty("mail.transport.protocol", "smtp");

    /**SSL认证,注意腾讯邮箱是基于SSL加密的,所有需要开启才可以使用**/
    MailSSLSocketFactory sf = new MailSSLSocketFactory();
    sf.setTrustAllHosts(true);
    props.put("mail.smtp.ssl.enable", "true");
    props.put("mail.smtp.ssl.socketFactory", sf);

    //创建会话
    Session session = Session.getInstance(props);

    //发送的消息,基于观察者模式进行设计的
    Message msg = new MimeMessage(session);
    msg.setSubject(emailTitle);
    //使用StringBuilder,因为StringBuilder加载速度会比String快,而且线程安全性也不错
    StringBuilder builder = new StringBuilder();
    builder.append("\n"+emailContent);
    builder.append("\n时间 " + new Date());
    msg.setText(builder.toString());
    msg.setFrom(new InternetAddress("你的QQ邮箱"));

    Transport transport = session.getTransport();
    transport.connect("smtp.qq.com", "你的QQ邮箱", "你开启SMTP服务申请的独立密码");
    //发送消息
    transport.sendMessage(msg, new Address[] { new InternetAddress(toEmailAddress) });
    transport.close();
  }
}

然后写个SpringMVC框架的Controller类:

  /**
   * 跳转到发送邮件页面
   * @return
   * @throws Exception
   */
  @RequestMapping("/goSendEmail")
  public ModelAndView goSendEmail(HttpServletRequest request)throws Exception{
    ModelAndView mv = this.getModelAndView();
    String email = request.getParameter("email");
    if(email!=null&&!"".equals(email)){
      email = email.trim();
      mv.setViewName("member/send_email");
      mv.addObject("email", email);
    }
    return mv;
  }

  /**
   * 发送邮件
   * @return
   * @throws Exception
   */
  @RequestMapping(value="/sendEmail",produces="application/json;charset=UTF-8")
  @ResponseBody
  public Object sendEmail(HttpServletRequest request)throws Exception{
    Map<String,String> map = new HashMap<String,String>();
    String msg = "ok";   //发送状态
    String toEMAIL = request.getParameter("EMAIL");         //对方邮箱
    String TITLE = request.getParameter("TITLE");          //标题
    String CONTENT = request.getParameter("CONTENT");        //内容
    JavaEmailSender.sendEmail(toEMAIL, TITLE, CONTENT);
    map.put("result", msg);
    return map;
  }

这里用了jQuery TIP插件进行验证提示,所以需要引入相应的Jquery文件

<script type="text/javascript" src="source/js/jquery-1.7.2.js"></script>
  <!--提示框-->
  <script type="text/javascript" src="source/js/jquery.tips.js"></script>

Jquery表单验证和Ajax异步请求:

<!-- 发送邮件 -->
  <script type="text/javascript">
//发送
function sendEm(){

  if($("#TYPE").val()=="1"){
    $("#CONTENT").val(getContentTxt());
  }else{
    $("#CONTENT").val(getContent());
  }
  if($("#EMAIL").val()==""){
    $("#EMAIL").tips({
      side:3,
      msg:'请输入邮箱',
      bg:'#AE81FF',
      time:2
    });
    $("#EMAIL").focus();
    return false;
  }
  if($("#TITLE").val()==""){
    $("#TITLE").tips({
      side:3,
      msg:'请输入标题',
      bg:'#AE81FF',
      time:2
    });
    $("#TITLE").focus();
    return false;
  }
  if($("#CONTENT").val()==""){

    $("#nr").tips({
      side:1,
      msg:'请输入内容',
      bg:'#AE81FF',
      time:3
    });
    return false;
  }

  var EMAIL = $("#EMAIL").val();
  var TYPE = $("#TYPE").val();
  var TITLE = $("#TITLE").val();
  var CONTENT = $("#CONTENT").val();

  $("#zhongxin").hide();
  $("#zhongxin2").show();

  $.ajax({
    type: "POST",
    url: 'retroaction/sendEmail.do?tm='+new Date().getTime(),
    data: {EMAIL:EMAIL,TITLE:TITLE,CONTENT:CONTENT},
    dataType:'json',
    //beforeSend: validateData,
    cache: false,
    success: function(data){
      if("ok" == data.result){
        $("#msg").tips({
            side:3,
            msg:'发送成功!',
            bg:'#68B500',
            time:5
           });
        setTimeout("showdiv()",1000);  
      }else{
        $("#msg").tips({
            side:3,
            msg:'发送失败!',
            bg:'#68B500',
            time:5
           });
      }

    }
  });

}

</script>

JSP页面的调用:

<!-- 编辑邮箱 -->
    <div>
    <table style="width:98%;" >
      <tr>
        <td style="margin-top:0px;">
           <div style="float: left;" style="width:81%"><textarea name="EMAIL" id="EMAIL" rows="1" cols="50" style="width:600px;height:20px;" placeholder="请选输入对方邮箱,多个请用(;)分号隔开" title="请选输入对方邮箱,多个请用(;)分号隔开">${email}</textarea></div>
           <div style="float: right;" style="width:19%"><a class='btn btn-mini btn-info' title="编辑邮箱" onclick="dialog_open();">编辑邮箱</i></a></div>
        </td>
      </tr>
      <tr>
        <td>
           <input type="text" name="TITLE" id="TITLE" value="" placeholder="请选输入邮件标题" style="width:98%"/>
        </td>
      </tr>
      <tr>
        <td id="nr">
           <script id="editor" type="text/plain" style="width:650px;height:259px;"></script>
        </td>
      </tr>
      <tr>
        <td style="text-align: center;">
          <a class="btn btn-mini btn-primary" onclick="sendEm();">发送</a>
          <a class="btn btn-mini btn-danger" onclick="top.Dialog.close();">取消</a>
        </td>
      </tr>
    </table>
    </div>
    <div id="zhongxin2" class="center" style="display:none"><br/><img src="assets/images/jzx.gif" id='msg' /><br/><h4 class="lighter block green" id='msg'>正在发送...</h4></div>    

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

相关文章

  • 基于mybatis batch实现批量提交大量数据

    基于mybatis batch实现批量提交大量数据

    这篇文章主要介绍了基于mybatis batch实现批量提交大量数据,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-05-05
  • Java执行JavaScript代码

    Java执行JavaScript代码

    这篇文章主要为大家详细介绍了Java执行JavaScript代码的具体操作方法,感兴趣的小伙伴们可以参考一下
    2016-03-03
  • MyBatis主键自增的两种实现方法

    MyBatis主键自增的两种实现方法

    本文主要介绍了MyBatis主键自增的两种实现方法,主要包括注解方式或配置文件方式来实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2024-01-01
  • Java泛型的继承和实现操作示例

    Java泛型的继承和实现操作示例

    这篇文章主要介绍了Java泛型的继承和实现操作,结合实例形式分析了java泛型类的继承以及泛型接口的实现相关操作技巧,需要的朋友可以参考下
    2019-08-08
  • java中对象的比较equal、Comparble、Comparator的区别

    java中对象的比较equal、Comparble、Comparator的区别

    本文主要介绍了java中对象的比较equal、Comparble、Comparator的区别,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-10-10
  • Spring MVC DispatcherServlet处理请求过程示例详解

    Spring MVC DispatcherServlet处理请求过程示例详解

    这篇文章主要介绍了Spring MVC DispatcherServlet处理请求过程示例解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-09-09
  • 使用java web 在jsp文件及Class中连接MySQL和SQLserver 的驱动方法

    使用java web 在jsp文件及Class中连接MySQL和SQLserver 的驱动方法

    这篇文章主要介绍了使用java web 在jsp文件及Class中连接MySQL和SQLserver的驱动方法的相关资料,本文介绍的非常详细,具有参考借鉴价值,需要的朋友可以参考下
    2016-10-10
  • 浅谈MyBatis 事务管理

    浅谈MyBatis 事务管理

    这篇文章主要介绍了浅谈MyBatis 事务管理,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-10-10
  • Java如何基于okhttp请求SSE接口流式返回详解

    Java如何基于okhttp请求SSE接口流式返回详解

    对于流式返回,Spring Boot提供了两种不同的方式,下面这篇文章主要给大家介绍了关于Java如何基于okhttp请求SSE接口流式返回的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2024-03-03
  • 关于MyBatis Plus中使用or和and问题

    关于MyBatis Plus中使用or和and问题

    这篇文章主要介绍了关于MyBatis Plus中使用or和and问题,需要的朋友可以参考下
    2020-12-12

最新评论