<pre name="code" class="java"><span style="font-family: Arial, Helvetica, sans-serif; background-color: rgb(255, 255, 255);">公司平台用户注册需要发送邮件接收验证码,就想到了Spring提供邮件发送功能,好了,废话不多说,看代码。</span>
<span style="font-family: Arial, Helvetica, sans-serif; background-color: rgb(255, 255, 255);"></span><pre name="code" class="java">//这是Service层,Control层直接调用send这个方法就可以了,Control层省略。
package com.maimai.service;
import java.util.Map;
import java.util.Set;
import javax.mail.internet.MimeMessage;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import org.springframework.mail.SimpleMailMessage;
import org.springframework.mail.javamail.JavaMailSender;
import org.springframework.mail.javamail.JavaMailSenderImpl;
import org.springframework.mail.javamail.MimeMessageHelper;
import org.springframework.scheduling.annotation.Async;
import org.springframework.stereotype.Service;
import com.maimai.dao.SystemMailTemplateDao;
import com.maimai.db_bean.SystemMailTemplate;
@Service
public class MailSendService {
@Autowired
private JavaMailSender mailSender;
@Autowired
private SystemMailTemplateDao mailTemplateDao;
@Async
public void send(Map<String,Object> params){
SimpleMailMessage mail = new SimpleMailMessage();
try {
// mail.setText("springMail的简单发送测试");// 邮件内容
SystemMailTemplate mailTemplate = mailTemplateDao.findByTemplateType(params.get("templateType").toString());
JavaMailSenderImpl senderImpl = new JavaMailSenderImpl();
MimeMessage mailMessage = senderImpl.createMimeMessage();
MimeMessageHelper messageHelper = new MimeMessageHelper(mailMessage,true,"utf-8");
messageHelper.setTo(params.get("receiver").toString());// 接受者
messageHelper.setFrom(mailTemplate.getSender());// 发送者,这里还可以另起Email别名,不用和xml里的username一致
messageHelper.setSubject(mailTemplate.getTitle());// 主题
Set<String> keys = params.keySet();
String content = mailTemplate.getContent();
for(String key : keys){
if("receiver".equals(key) || "templateType".equals(key)){
continue;
}
content = content.replace("${"+key+"}", params.get(key).toString());
}
messageHelper.setText(content,true);
mailSender.send(mailMessage);
} catch (Exception e) {
e.printStackTrace();
}
}
}
//Dao层,使用Mybatis
<span style="font-family: Arial, Helvetica, sans-serif; background-color: rgb(255, 255, 255);"></span><pre name="code" class="java">package com.maimai.dao;
import java.util.List;
import java.util.Map;
import com.maimai.db_bean.SystemMailTemplate;
public interface SystemMailTemplateDao {
public void insert(SystemMailTemplate systemMailTemplate);
public void update(SystemMailTemplate systemMailTemplate);
public void deleteById(long id);
public SystemMailTemplate findByTemplateType(String templateType);
public SystemMailTemplate findById(long id);
public List<SystemMailTemplate> findAll(Map<String,Object> params);
public long findCountAll(Map<String,Object> params);
}
//配置文件
<span style="font-family: Arial, Helvetica, sans-serif; background-color: rgb(255, 255, 255);"></span><pre name="code" class="html"><!-- 邮件配置 -->
<context:property-placeholder location="classpath:mail.properties"/>
<bean id="mailSender" class="org.springframework.mail.javamail.JavaMailSenderImpl">
<property name="host" value="${mail.host}"/>
<property name="port" value="${mail.port}"/>
<property name="javaMailProperties">
<props>
<prop key="mail.smtp.auth">true</prop>
<prop key="mail.smtp.timeout">36000</prop>
</props>
</property>
<property name="username" value="${mail.username}" />
<property name="password" value="${mail.password}" />
</bean>
//邮件配置文件
<span style="font-family: Arial, Helvetica, sans-serif; background-color: rgb(255, 255, 255);"></span><pre name="code" class="plain">mail.host=smtp.126.com
mail.port=25
mail.username=发件人邮箱
mail.password=邮箱密码
//数据库设计
<pre name="code" class="sql">CREATE TABLE `system_mail_template` (
`id` int(11) NOT NULL auto_increment,
`title` varchar(255) NOT NULL COMMENT '标题',
`createTime` timestamp NULL default CURRENT_TIMESTAMP on update CURRENT_TIMESTAMP COMMENT '创建日期',
`sender` varchar(255) NOT NULL COMMENT '发件人',
`content` text NOT NULL COMMENT '邮件内容',
`templateType` varchar(255) default NULL COMMENT '预留字段,邮件模板类型',
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8;