热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

Spring+quartz实现定时发送邮件功能实例

spring提供的定时发送邮件功能一直深受广大web开发者的喜爱,这篇文章主要介绍了Spring+quartz实现定时发送邮件功能实例,有兴趣的可以了解一下。

在做具体的系统管理时,往往会有每隔一段时间发给用户一些邮件的业务,现在参考的网上的大部分代码,写下了我自己的代码。

在ApplicationContext.xml的内容如下:

<&#63;xml version="1.0" encoding="UTF-8"&#63;>



 
 
 
  
  
  
  
   sendEmail
  
  
   false
  
 
  
   
   
    
    
    
    
    0 0 10 1 * &#63; 
    
   
  
 
  
   
  
 
 




至于方法如下:

package com.zhuyun.net;

import java.io.BufferedWriter;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.FileWriter;
import java.io.IOException;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import java.io.OutputStream;
import java.io.OutputStreamWriter;
import java.io.Writer;
import java.sql.SQLException;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Calendar;
import java.util.Date;
import java.util.List;
import java.util.Properties;

import javax.activation.DataHandler;
import javax.activation.DataSource;
import javax.activation.FileDataSource;
import javax.mail.BodyPart;
import javax.mail.Message;
import javax.mail.Multipart;
import javax.mail.Session;
import javax.mail.Transport;
import javax.mail.internet.InternetAddress;
import javax.mail.internet.MimeBodyPart;
import javax.mail.internet.MimeMessage;
import javax.mail.internet.MimeMultipart;



public class AttachmentEmailUtil {

 private String host = ""; // smtp服务器
 private String from = ""; // 发件人地址
 private String to = ""; // 收件人地址
 private String affix = ""; // 附件地址
 private String affixName = ""; // 附件名称
 private String user = ""; // 用户名
 private String pwd = ""; // 密码
 private String subject = ""; // 邮件标题

 public void setAddress(String from, String to, String subject) {
  this.from = from;
  this.to = to;
  this.subject = subject;
 }

 public void setAffix(String affix, String affixName) {
  this.affix = affix;
  this.affixName = affixName;
 }

 public void send(String host, String user, String pwd) {
  this.host = host;
  this.user = user;
  this.pwd = pwd;

  Properties props = new Properties();

  // 设置发送邮件的邮件服务器的属性(这里使用网易的smtp服务器)
  props.put("mail.smtp.host", host);
  // 需要经过授权,也就是有户名和密码的校验,这样才能通过验证
  props.put("mail.smtp.auth", "true");
  props.put("mail.smtp.port", 465);
  props.put("mail.smtp.ssl.enable", true);
  // 用刚刚设置好的props对象构建一个session
  Session session = Session.getDefaultInstance(props);

  // 有了这句便可以在发送邮件的过程中在console处显示过程信息,供调试使
  // 用(你可以在控制台(console)上看到发送邮件的过程)
  session.setDebug(true);

  // 用session为参数定义消息对象
  MimeMessage message = new MimeMessage(session);
  try {
   // 加载发件人地址
   message.setFrom(new InternetAddress(from));
   // 加载收件人地址
   message.addRecipient(Message.RecipientType.TO, new InternetAddress(
     to));
   // 加载标题
   message.setSubject(subject);

   // 向multipart对象中添加邮件的各个部分内容,包括文本内容和附件
   Multipart multipart = new MimeMultipart();

   // 设置邮件的文本内容
   BodyPart cOntentPart= new MimeBodyPart();
   contentPart.setText("第二种方法···");
   multipart.addBodyPart(contentPart);
   // 添加附件
   BodyPart messageBodyPart = new MimeBodyPart();
   DataSource source = new FileDataSource(affix);
   // 添加附件的内容
   messageBodyPart.setDataHandler(new DataHandler(source));
   // 添加附件的标题
   // 这里很重要,通过下面的Base64编码的转换可以保证你的中文附件标题名在发送时不会变成乱码
   sun.misc.BASE64Encoder enc = new sun.misc.BASE64Encoder();
   messageBodyPart.setFileName("=&#63;GBK&#63;B&#63;"
     + enc.encode(affixName.getBytes()) + "&#63;=");
   multipart.addBodyPart(messageBodyPart);

   // 将multipart对象放到message中
   message.setContent(multipart);
   // 保存邮件
   message.saveChanges();
   // 发送邮件
   Transport transport = session.getTransport("smtp");
   // 连接服务器的邮箱
   transport.connect(host, user, pwd);
   // 把邮件发送出去
   transport.sendMessage(message, message.getAllRecipients());
   transport.close();
  } catch (Exception e) {
   e.printStackTrace();
  }
 }

 public void sendEmail() {
  File file = new File("/root/EmailFile/content.csv");
  if (!file.exists()) {
   try {
    file.createNewFile();
   } catch (IOException e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
   }
  }
  String pushInfoCOntent= "成功了";

  FileWriter writer = null;
  try {
   // 打开一个写文件器,构造函数中的第二个参数true表示以追加形式写文件
   writer = new FileWriter(file, true);
   writer.write(pushInfoContent + "\r\n");
  } catch (IOException e) {
   e.printStackTrace();
  } finally {
   try {
    if (writer != null) {
     writer.close();
    }
   } catch (IOException e) {
    e.printStackTrace();
   }
  }

  AttachmentEmailUtil cn = new AttachmentEmailUtil();
  // 设置发件人地址、收件人地址和邮件标题
  cn.setAddress("发件人地址", "收件人地址", "一个带附件的JavaMail邮件(标题)");
  // 设置要发送附件的位置和标题
  cn.setAffix("附件的位置", "附件的文件名");
  // 设置smtp服务器以及邮箱的帐号和密码
  cn.send("smtp.qq.com", "帐号", "密码");

  if (file.exists()) {
   file.delete();
  }
 }
}

大概就是这样子了。

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


推荐阅读
  • 本文详细介绍了IBM DB2数据库在大型应用系统中的应用,强调其卓越的可扩展性和多环境支持能力。文章深入分析了DB2在数据利用性、完整性、安全性和恢复性方面的优势,并提供了优化建议以提升其在不同规模应用程序中的表现。 ... [详细]
  • Windows服务与数据库交互问题解析
    本文探讨了在Windows 10(64位)环境下开发的Windows服务,旨在定期向本地MS SQL Server (v.11)插入记录。尽管服务已成功安装并运行,但记录并未正确插入。我们将详细分析可能的原因及解决方案。 ... [详细]
  • 本文详细介绍了如何使用PHP检测AJAX请求,通过分析预定义服务器变量来判断请求是否来自XMLHttpRequest。此方法简单实用,适用于各种Web开发场景。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 深入理解 SQL 视图、存储过程与事务
    本文详细介绍了SQL中的视图、存储过程和事务的概念及应用。视图为用户提供了一种灵活的数据查询方式,存储过程则封装了复杂的SQL逻辑,而事务确保了数据库操作的完整性和一致性。 ... [详细]
  • 本文探讨了 RESTful API 和传统接口之间的关键差异,解释了为什么 RESTful API 在设计和实现上具有独特的优势。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • 在当前众多持久层框架中,MyBatis(前身为iBatis)凭借其轻量级、易用性和对SQL的直接支持,成为许多开发者的首选。本文将详细探讨MyBatis的核心概念、设计理念及其优势。 ... [详细]
  • MySQL缓存机制深度解析
    本文详细探讨了MySQL的缓存机制,包括主从复制、读写分离以及缓存同步策略等内容。通过理解这些概念和技术,读者可以更好地优化数据库性能。 ... [详细]
  • MySQL 数据库迁移指南:从本地到远程及磁盘间迁移
    本文详细介绍了如何在不同场景下进行 MySQL 数据库的迁移,包括从一个硬盘迁移到另一个硬盘、从一台计算机迁移到另一台计算机,以及解决迁移过程中可能遇到的问题。 ... [详细]
  • Docker的安全基准
    nsitionalENhttp:www.w3.orgTRxhtml1DTDxhtml1-transitional.dtd ... [详细]
  • 本文介绍如何解决在 IIS 环境下 PHP 页面无法找到的问题。主要步骤包括配置 Internet 信息服务管理器中的 ISAPI 扩展和 Active Server Pages 设置,确保 PHP 脚本能够正常运行。 ... [详细]
  • 在使用SQL Server进行动态SQL查询时,如果遇到LIKE语句无法正确返回预期结果的情况,通常是因为参数传递方式不当。本文将详细探讨这一问题,并提供解决方案及相关的技术背景。 ... [详细]
  • 本文介绍如何通过创建替代插入触发器,使对视图的插入操作能够正确更新相关的基本表。涉及的表包括:飞机(Aircraft)、员工(Employee)和认证(Certification)。 ... [详细]
  • 精选30本C# ASP.NET SQL中文PDF电子书合集
    欢迎订阅我们的技术博客,获取更多关于C#、ASP.NET和SQL的最新资讯和资源。 ... [详细]
author-avatar
新手村一霸
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有