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

本文详细介绍了如何在基于Spring4.0+SpringMVC+Mybatis的SSM框架中使用Javamail发送邮件,以腾讯QQ邮箱为例,讲解SMTP协议和SSL加密,并提供完整的代码实现,包括业务类和SpringMVC Controller的编写。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

本篇文章主要介绍了基于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:

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

image.png

写个发送邮件的业务类:

|

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类:在此我向大家推荐一个架构学习交流圈。交流学习指导伪鑫:1253431195(里面有大量的面试题及答案)里面会分享一些资深架构师录制的视频录像:有Spring,MyBatis,Netty源码分析,高并发、高性能、分布式、微服务架构的原理,JVM性能优化、分布式架构等这些成为架构师必备的知识体系。还能领取免费的学习资源,目前受益良多

|

/**

* 跳转到发送邮件页面

* @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>   

|

image.png

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值