array(2) { ["docs"]=> array(10) { [0]=> array(10) { ["id"]=> string(3) "428" ["text"]=> string(77) "Visual Studio 2017 单独启动MSDN帮助(Microsoft Help Viewer)的方法" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(8) "DonetRen" ["tagsname"]=> string(55) "Visual Studio 2017|MSDN帮助|C#程序|.NET|Help Viewer" ["tagsid"]=> string(23) "[401,402,403,"300",404]" ["catesname"]=> string(0) "" ["catesid"]=> string(2) "[]" ["createtime"]=> string(10) "1511400964" ["_id"]=> string(3) "428" } [1]=> array(10) { ["id"]=> string(3) "427" ["text"]=> string(42) "npm -v;报错 cannot find module "wrapp"" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(4) "zzty" ["tagsname"]=> string(50) "node.js|npm|cannot find module "wrapp“|node" ["tagsid"]=> string(19) "[398,"239",399,400]" ["catesname"]=> string(0) "" ["catesid"]=> string(2) "[]" ["createtime"]=> string(10) "1511400760" ["_id"]=> string(3) "427" } [2]=> array(10) { ["id"]=> string(3) "426" ["text"]=> string(54) "说说css中pt、px、em、rem都扮演了什么角色" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(12) "zhengqiaoyin" ["tagsname"]=> string(0) "" ["tagsid"]=> string(2) "[]" ["catesname"]=> string(0) "" ["catesid"]=> string(2) "[]" ["createtime"]=> string(10) "1511400640" ["_id"]=> string(3) "426" } [3]=> array(10) { ["id"]=> string(3) "425" ["text"]=> string(83) "深入学习JS执行--创建执行上下文(变量对象,作用域链,this)" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(7) "Ry-yuan" ["tagsname"]=> string(33) "Javascript|Javascript执行过程" ["tagsid"]=> string(13) "["169","191"]" ["catesname"]=> string(0) "" ["catesid"]=> string(2) "[]" ["createtime"]=> string(10) "1511399901" ["_id"]=> string(3) "425" } [4]=> array(10) { ["id"]=> string(3) "424" ["text"]=> string(30) "C# 排序技术研究与对比" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(9) "vveiliang" ["tagsname"]=> string(0) "" ["tagsid"]=> string(2) "[]" ["catesname"]=> string(8) ".Net Dev" ["catesid"]=> string(5) "[199]" ["createtime"]=> string(10) "1511399150" ["_id"]=> string(3) "424" } [5]=> array(10) { ["id"]=> string(3) "423" ["text"]=> string(72) "【算法】小白的算法笔记:快速排序算法的编码和优化" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(9) "penghuwan" ["tagsname"]=> string(6) "算法" ["tagsid"]=> string(7) "["344"]" ["catesname"]=> string(0) "" ["catesid"]=> string(2) "[]" ["createtime"]=> string(10) "1511398109" ["_id"]=> string(3) "423" } [6]=> array(10) { ["id"]=> string(3) "422" ["text"]=> string(64) "JavaScript数据可视化编程学习(二)Flotr2,雷达图" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(7) "chengxs" ["tagsname"]=> string(28) "数据可视化|前端学习" ["tagsid"]=> string(9) "[396,397]" ["catesname"]=> string(18) "前端基本知识" ["catesid"]=> string(5) "[198]" ["createtime"]=> string(10) "1511397800" ["_id"]=> string(3) "422" } [7]=> array(10) { ["id"]=> string(3) "421" ["text"]=> string(36) "C#表达式目录树(Expression)" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(4) "wwym" ["tagsname"]=> string(0) "" ["tagsid"]=> string(2) "[]" ["catesname"]=> string(4) ".NET" ["catesid"]=> string(7) "["119"]" ["createtime"]=> string(10) "1511397474" ["_id"]=> string(3) "421" } [8]=> array(10) { ["id"]=> string(3) "420" ["text"]=> string(47) "数据结构 队列_队列实例:事件处理" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(7) "idreamo" ["tagsname"]=> string(40) "C语言|数据结构|队列|事件处理" ["tagsid"]=> string(23) "["246","247","248",395]" ["catesname"]=> string(12) "数据结构" ["catesid"]=> string(7) "["133"]" ["createtime"]=> string(10) "1511397279" ["_id"]=> string(3) "420" } [9]=> array(10) { ["id"]=> string(3) "419" ["text"]=> string(47) "久等了,博客园官方Android客户端发布" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(3) "cmt" ["tagsname"]=> string(0) "" ["tagsid"]=> string(2) "[]" ["catesname"]=> string(0) "" ["catesid"]=> string(2) "[]" ["createtime"]=> string(10) "1511396549" ["_id"]=> string(3) "419" } } ["count"]=> int(200) } 222 JCrontab简单入门实例 - 爱码网

创建一个JavaWeb项目

 JCrontab简单入门实例

 JCrontab简单入门实例

1,首先要下载JCrontab的相关jar包,Jcrontab-2.0-RC0.jar。放到lib文件夹下。

 JCrontab简单入门实例JCrontab简单入门实例

 

2,在src下新建文件jcrontab.properties如下:

 JCrontab简单入门实例JCrontab简单入门实例JCrontab简单入门实例JCrontab简单入门实例

#crontab.xml文件的目录,这个是作业调度规则

org.jcrontab.data.file =E:/EclipseWorkspace/ADemo/WebContent/WEB-INF/crontab.xml

#sax解析驱动类型

org.xml.sax.driver=org.apache.xerces.parsers.SAXParser

#datasource文件类型

org.jcrontab.data.datasource=org.jcrontab.data.XMLSource

 

3,在WEB-INF下新建文件crontab.xml

 JCrontab简单入门实例JCrontab简单入门实例

<?xml version="1.0" encoding="utf-8"?>

<crontab>

<crontabentry id="2014">

<seconds>0,5,10,15,20,25,30,35,40,45,50,55</seconds>

<minutes>*</minutes>

<hours>*</hours>

<daysofmonth>*</daysofmonth>

<months>*</months>

<daysofweek>*</daysofweek>

<years>*</years>

<bussinesdays>true</bussinesdays>

<startDate></startDate>

<endDate></endDate>

<class>xu.crontab.Crontab1</class>

<method>run</method>

<parameters></parameters>

<description></description>

</crontabentry>

</crontab>

 

以上属性自己百度一下,<seconds>0,5,10,15,20,25,30,35,40,45,50,55</seconds>这个是秒数是5的倍数就调用作业

 

4web.xml配置如下

<?xml version="1.0" encoding="UTF-8"?>

<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

xmlns="http://xmlns.jcp.org/xml/ns/javaee"

xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"

id="WebApp_ID" version="3.1">

<display-name>ADemo</display-name>

 

<servlet>

<servlet-name>LoadOnStartupServlet</servlet-name>

<servlet-class>xu.crontab.LoadCrontabServlet</servlet-class>

<init-param>

<param-name>PROPERTIES_FILE</param-name>

<!--此处路径是绝对路径 -->

<param-value>E:\EclipseWorkspace\ADemo\src\jcrontab.properties</param-value>

</init-param>

<load-on-startup>1</load-on-startup>

</servlet>

<servlet-mapping>

<servlet-name>LoadOnStartupServlet</servlet-name>

<url-pattern>/Startup</url-pattern>

</servlet-mapping>

</web-app>

 

5,在xu.crontab包下新建两个java文件(文件位置见最上的截图)【其他java文件不用理会】

 JCrontab简单入门实例JCrontab简单入门实例

LoadCrontabServlet.java

package xu.crontab;

 

import java.io.FileInputStream;

import java.io.IOException;

import java.io.InputStream;

import java.util.Enumeration;

import java.util.Properties;

 

import javax.servlet.ServletConfig;

import javax.servlet.ServletException;

import javax.servlet.http.HttpServlet;

 

import org.jcrontab.Crontab;

import org.jcrontab.log.Log;

 

public class LoadCrontabServlet extends HttpServlet {

 

/**

 *

 */

private static final long serialVersionUID = 1L;

private Crontab cron = null;

 

public void init(ServletConfig config) throws ServletException {

super.init(config);

 

try {

System.out.print("Working?...");

process();

System.out.println("OK");

} catch (Exception e) {

throw new ServletException(e);

}

}

 

protected InputStream createPropertiesStream(String name) throws IOException {

return new FileInputStream(name);

}

 

public void process() {

 

String propz = "jcrontab.properties";

 

String props = getServletConfig().getInitParameter("PROPERTIES_FILE");

if (props == null) {

props = propz;

}

 

Properties propObj = new Properties();

try {

InputStream input = createPropertiesStream(props);

propObj.load(input);

} catch (IOException ioe) {

ioe.printStackTrace();

}

ServletConfig c = getServletConfig();

Enumeration keys = c.getInitParameterNames();

while (keys.hasMoreElements()) {

String key = (String) keys.nextElement();

propObj.setProperty(key, c.getInitParameter(key));

}

 

cron = Crontab.getInstance();

 

try {

ShutdownHook();

cron.init(propObj);

} catch (Exception e) {

Log.error(e.toString(), e);

}

}

 

 

public void ShutdownHook() throws Exception {

Runtime.getRuntime().addShutdownHook(new Thread() {

public void run() {

doStop();

}

});

}

 

public void destroy() {

doStop();

}

 

public void doStop() {

Log.info("Shutting down...");

cron.uninit(100);

Log.info("Stoped");

}

}

 

Crontab1.java

package xu.crontab;

 

import java.util.Date;

 

public class Crontab1 {

    public static void run(String[] args) {

       System.out.println(new Date()+"-----> hello world!!!");

    }

}

启动tomcat后即可看到作业每隔5秒就调用一下,希望你们顺利。

JCrontab简单入门实例JCrontab简单入门实例


如有不清楚地方请自行百度搜索更多相关资料或者给我留言。

 

相关文章: