=============JAVA后台代码=====================

package com.qgc.service.autoSendMsg.AutoSendMsg

import java.io.File;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
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;

import com.gzbugu.common.service.impl.BaseService;
import com.gzbugu.common.util.JxlsUtils;
import com.gzbugu.dzz.domain.DzzUserinfo;

/**
 * 自动导出数据,并发送邮件个用户
 * @author http://cnblogs.com/qgc88
 *
 */
public class AutoSendMsg  {
    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 = ""; //邮件标题
     private String count="";//文件内容

public void sendEmail() {
        try {
            
        
        String hql = " from DzzUserinfo o where enabled =1 ";
        List<DzzUserinfo> list = commonDao.getListByHQL(hql);
        SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HHmmss");
        
        String bathPath = this.getClass().getClassLoader().getResource("")
                .getPath();
        //bathPath=bathPath.substring(1,bathPath.length());
        
        bathPath=bathPath.substring(1,bathPath.lastIndexOf("WEB-INF"))+"dzz"+"/newOrderData/";
        File file=new File(bathPath);
        if(!file.exists()){
            file.mkdirs();
        }
        
        String flileName=sdf.format(new Date())+".xls";
        String tempPath =bathPath+flileName;
        String template =bathPath+"newOrder_template.xls";
        
        // 采用jxls模板方式导出
        Map params = new HashMap();
        params.put("list", list);
        JxlsUtils.createExcel(template, params, tempPath);
        System.out.println(tempPath);
          //设置发件人地址、收件人地址和邮件标题
         setAddress("发送人邮箱@qq.com","收件人邮箱@qq.com",flileName+",大中专学生最新报订数据!");
         //设置要发送附件的位置和标题
         setAffix(tempPath,flileName);
         
         count="大中专学生最新报订数据,详情请查收附件,谢谢!";
         
         //设置smtp服务器以及邮箱的帐号和密码
         send("发送人邮箱@qq.com","发送人邮箱密码");
        } catch (Exception e) {
            e.printStackTrace();
        }
         
        }
    
    
    
     public void send(String user,String pwd) {
         this.user = user;
         this.pwd  = pwd;
         
         this.host = "smtp."
                    + from.substring(from.indexOf('@') + 1, from.length()); // 在Internet上发送
         
            Properties props = new Properties();
           
            //设置发送邮件的邮件服务器的属性(这里使用网易的smtp服务器)
            props.put("mail.smtp.host", host);
            //需要经过授权,也就是有户名和密码的校验,这样才能通过验证(一定要有这一条)
            props.put("mail.smtp.auth", "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(count);
                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("=?GBK?B?"+enc.encode(affixName.getBytes())+"?=");
                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 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;
         }

}

===============application.xml定时配置=================================

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:tx="http://www.springframework.org/schema/tx"
    xmlns:aop="http://www.springframework.org/schema/aop" xmlns:context="http://www.springframework.org/schema/context"
    xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
                                    http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.0.xsd
                                    http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd
                                    http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.0.xsd"
    default-autowire="byName" default-lazy-init="true">
 <!--一个普通对象-->
    <bean id="autoSendMsg" class="com.qgc.service.autoSendMsg.AutoSendMsg"/>
    
    <bean id="autoSendMsgTaskInit" class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">
        <!--设置为定时调用的对象-->
        <property name="targetObject">
            <ref local="autoSendMsg" />
        </property>
        <!--设置对象里某一个方法为定时工作的方法-->
        <property name="targetMethod">
            <value>sendEmail</value>
        </property>
     </bean>
    <bean id="autoSendMsgTrigger" class="org.springframework.scheduling.quartz.CronTriggerBean">
        <!--把定时对象加入定时器-->
        <property name="jobDetail">  
               <ref local="autoSendMsgTaskInit"/>  
          </property>
        <!--设置时间的调用规制-->
          <property name="cronExpression">
          <!--0 15 10 ? * * 每天23点140分触发   -->   
                <value>0 40 23 ? * * </value>  
              </property>  
    </bean>
 
    <bean id="autoSendMsgScheduler" class="org.springframework.scheduling.quartz.SchedulerFactoryBean" >
         <!--把定时器加入管理器-->
         <property name="triggers">
           <list>
             <ref bean="autoSendMsgTrigger"/>
           </list>
         </property>
    </bean>

</beans>

===================newOrder_template.xls导出模版==================================

java使用jxl,自动导出数据excle,quartz自动发送邮件的更多相关文章

  1. Java操作Jxl实现导出数据生成Excel表格数据文件

    实现:前台用的框架是Easyui+Bootstrap结合使用,需要引入相应的Js.Css文件.页面:Jsp.拦截请求:Servlet.逻辑处理:ClassBean.数据库:SQLserver. 注意: ...

  2. JAVA WEB ------ 文件下载及导出数据到office Execl表格

    文件下载需要五步: 1.设置文件ContentType类型 // 设置文件ContentType类型,这样设置,会自动判断下载文件类型 response.setContentType("mu ...

  3. java struts jxl 导入导出Excel(无模板)

    jar包: import javax.servlet.http.HttpServletResponse; import java.io.OutputStream; import java.io.Fil ...

  4. java用jxl实现导出execl表格

    //先将需要导出的数据放到list中 //然后将list中的数据放到execl表中 @RequestMapping(params="exportExecl") public Str ...

  5. java实现excel表格导出数据

    /** * 导出清单 eb中 firstRow(EntityBean) 列表第一行数据,键值对(不包含序号)例:("name","姓名") * data(Ent ...

  6. java POI技术之导出数据优化(15万条数据1分多钟)

    专针对导出excel2007 ,用到poi3.9的jar package com.cares.ynt.util; import java.io.File; import java.io.FileOut ...

  7. java从ldap中导出数据到ldif文件中

    原创:http://www.cnblogs.com/dqcer/p/7814034.html 导入ldap.jar包,笔者已对下面两个文件测试并通过.若有疑问欢迎留言 LDAPExport.java ...

  8. Java操作Jxl实现数据交互。三部曲——《第一篇》

    Java操作Jxl实现.xsl及.xsls两种数据表格进行批量导入数据到SQL server数据库. 本文实现背景Web项目:前台用的框架是Easyui+Bootstrap结合使用,需要引入相应的Js ...

  9. hibernate中.hbm.xml和注解方式自动生成数据表的简单实例(由新手小白编写,仅适用新手小白)

    绝逼新手小白,so 请大神指点! 如果真的错的太多,错的太离谱,错的误导了其他小伙伴,还望大神请勿喷,大神请担待,大神请高抬贵嘴......谢谢. 好了,正题 刚接触ssh,今天在搞使用.hbm.xm ...

随机推荐

  1. int型除以int型

    int型除以int型得到的还是int型 就算你是这样的:float a = 5/3,虽然你定义的a是float型,但a得到的结果依旧是1.0000而不是1.66666 5/3先得到1,然后再转换成1. ...

  2. python之道04

    1.写代码,有如下列表,按照要求实现每一个功能 li = ["alex", "WuSir", "ritian", "barry&q ...

  3. Shell脚本中时间处理

    Shell脚本中时间处理 1.脚本内容 #!/bin/bash #环境变量 #设置环境变量和sql文件格式相符 source /etc/profileexport LD_LIBRARY_PATH=&q ...

  4. PLAYGROUND 可视化

    PLAYGROUND 可视化 由 王巍 (@ONEVCAT) 发布于 2015/09/23 在程序界,很多小伙伴都会对研究排序算法情有独钟,并且试图将排序执行的过程可视化,以便让大家更清晰直观地了解算 ...

  5. 移动网页端HTML5 meta便签

    width = device-width:标识宽度是设备屏幕的宽度 initial-scale = 1.0 :标识初始的缩放比例 minimum-scale =0.5 :表示最小的缩放比例 maxim ...

  6. CF547D Mike and Fish 建图

    题意: 有点长→CF547DMike and Fish. 分析: 其实也没什么好分析的,我这也是看的题解. (不过,那篇题解好像文字的代码不太对劲) 这里直接说做法,正确性自证: 对输入的,将横.纵坐 ...

  7. 【动态规划】bzoj1575: [Usaco2009 Jan]气象牛Baric

    预处理普通动态规划:庆祝1A三连 Description 为了研究农场的气候,Betsy帮助农夫John做了N(1 <= N <= 100)次气压测量并按顺序记录了结果M_1...M_N( ...

  8. CSS3-文本-word-wrap,word-break,white-space

    一.word-wrap使用: 语法: word-wrap : normal | break-word 取值说明: 1.normal为默认值,当其值为normal控制连续文本换行(允许内容顶开容器的边界 ...

  9. H.264 与 MPEG-4 压缩格式的变革

    h.264 和 mpeg-4 的关系: h.264 /avc ( advanced video coding )标准,是 mpeg-4 的第 10 部分. mpeg-4的初衷是将dvd质量的图像码流从 ...

  10. Ubuntu 16.04如何使用无线网卡上网

    我使用的无线网卡卡托型号是华为E8372h,网卡是普通电信卡(既可以打电话也可以上网). 按照“芯片朝上.缺口朝外.用最大卡”的方法将网卡装入卡托后,紧接着便将卡托插入笔记本对应的USB接口中. 在这 ...