首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 网站开发 > Web前端 >

web施用每晚12点定时执行程序代码实例

2012-11-03 
web应用每晚12点定时执行程序代码实例1、当前web应用的web.xml文件配置容器监听类com.isoftstone.zfmi.list

web应用每晚12点定时执行程序代码实例

1、当前web应用的web.xml文件配置容器监听类com.isoftstone.zfmi.listen.ZfmiContextListener

-------------------------------------------------

<listener>
?? <listener-class>
??? com.isoftstone.zfmi.listen.ZfmiContextListener
?? </listener-class>
</listener>

-------------------------------------------------

在<filter-mapping>后,<servlet>元素之前

2、容器监听类com.isoftstone.zfmi.listen.ZfmiContextListener

在应用初始化和结束时,分别执行其覆盖的contextInitialized() 和contextDestroyed()方法,在contextInitialized()方法里,通过定时器timer的schedule(new FinDataTimerTask(),operTime, 86400000)方法在指定时间反复执行 FinDataTimerTask()对象中run()方法的操作,operTime 为指定初次执行时间,86400000)为反复执行时间间隔毫秒数,当前设定为一天,调试时可设短。

ZfmiContextListener.java:

-------------------------------------------------

package com.isoftstone.zfmi.listen;

import java.io.IOException;
import java.util.Calendar;
import java.util.Date;
import java.util.Timer;

import javax.servlet.ServletContextEvent;
import javax.servlet.ServletContextListener;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServlet;

import org.apache.log4j.Logger;

public class ZfmiContextListener extends HttpServlet implements
?? ServletContextListener {
Logger log = Logger.getLogger(this.getClass());
Timer timer = new Timer();

Date operTime;
public void service(ServletRequest request, ServletResponse response)
??? throws ServletException, IOException {//

}

public void contextInitialized(ServletContextEvent sce) {
?? log.info("\n 执行应用监听器初始方法????? initialcontext....");
??
?? Calendar now=Calendar.getInstance();
?? now.add(Calendar.DATE, 1);
?? now.set(Calendar.HOUR_OF_DAY, 0);
?? now.set(Calendar.MINUTE, 0);
?? now.set(Calendar.SECOND, 0);
?? now.set(Calendar.MILLISECOND, 0);
?? log.info("\n时间now为:?? "+now.toString()+"???? 毫秒数:"+now.getTimeInMillis());
?? operTime=new Date(now.getTimeInMillis());
?? log.info("\n预设初始执行时间为:?? "+operTime);
?? timer.schedule(new FinDataTimerTask(),operTime, 86400000); //一天执行一次
//?? timer.schedule(new FinDataTimerTask(),operTime, 10000);?? //10秒钟执行一次,调试可用
}

public void contextDestroyed(ServletContextEvent sce) {
?? log.info("\n 执行应用监听器结束方法?????? destory context....");
?? timer.cancel();
}
}

-------------------------------------------------

3、定时任务类com.isoftstone.zfmi.listen.FinDataTimerTask

继承TimerTask,需要定时执行的操作写在其覆盖的run()方法里面

FinDataTimerTask.java:

-------------------------------------------------

package com.isoftstone.zfmi.listen;

import java.util.TimerTask;

import org.apache.log4j.Logger;

public class FinDataTimerTask extends TimerTask {
Logger log = Logger.getLogger(this.getClass());

public void run() {
?? //定时进行的操作
?? log.info("\n时间到,正在执行定时预设的操作....");
??
}
}

-------------------------------------------------

1 楼 qw123456lulu 2011-08-05   写的很清晰。

热点排行