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

作者:u014427391 时间:2022-04-28 11:59:04 

本篇介绍基于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服务:

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

写个发送邮件的业务类:


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>    

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

来源:http://blog.csdn.net/u014427391/article/details/53887801

标签:Javamail,发送邮件
0
投稿

猜你喜欢

  • java实例方法被覆盖,静态方法被隐藏Explain(详解)

    2022-07-20 08:05:03
  • Java获取Process子进程进程ID方法详解

    2022-09-01 13:21:08
  • IDEA插件EasyCode及MyBatis最优配置步骤详解

    2023-11-09 03:19:19
  • JavaWeb开发之【Tomcat 环境配置】MyEclipse+IDEA配置教程

    2022-05-04 12:50:18
  • RandomAccessFile简介_动力节点Java学院整理

    2021-12-18 09:02:15
  • Java有哪些操作字符串的类?区别在哪?

    2021-06-02 14:50:54
  • 改进c# 代码的五个技巧(二)

    2023-01-09 08:57:56
  • java WSDL接口webService实现方式

    2022-06-15 21:03:29
  • Java实现的日期处理类完整实例

    2023-12-08 00:16:10
  • 使用SpringBoot 配置Oracle和H2双数据源及问题

    2023-10-04 14:06:11
  • Flutter应用集成极光推送的实现示例

    2023-06-24 03:51:04
  • C#中利用LINQ to XML与反射把任意类型的泛型集合转换成XML格式字符串的方法

    2022-02-12 23:04:39
  • C#图像处理之木刻效果实现方法

    2022-05-20 04:28:13
  • java写入文件的几种方法分享

    2023-06-26 15:56:55
  • 解析Java中PriorityQueue优先级队列结构的源码及用法

    2023-11-08 13:33:11
  • Andriod使用多线程实现轮播图片

    2023-07-27 15:47:31
  • 实例讲解Java并发编程之闭锁

    2023-10-25 14:25:07
  • Java中logback 自动刷新不生效的问题解决

    2022-09-07 21:26:04
  • Java C++ 算法题解leetcode669修剪二叉搜索树示例

    2022-09-22 04:56:13
  • c#和java base64不一致的解决方法

    2022-11-24 02:18:55
  • asp之家 软件编程 m.aspxhome.com