cron表达式验证

写完cron表达式后,要验证下正确性在提交到配置文件中,下面发个简单的测试验证代码(含quartz包的项目就可以执行),如下: 

需要下载 quartz-all-1.6.0.jar

 

 

package com.cron.test;

import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Date;

import org.quartz.CronExpression;

public class CronTest {

	public static void main(String[] args) {
		cronTest();
	}

	private static void cronTest() {
		try {
			CronExpression exp = new CronExpression("0 0/1 * * * ?");
			SimpleDateFormat df = new SimpleDateFormat("yyyyMMdd HH:mm:ss");
			Date d = new Date();
			int i = 0;
			// 循环得到接下来n此的触发时间点,供验证
			while (i < 10) {
				d = exp.getNextValidTimeAfter(d);
				System.out.println(df.format(d));
				++i;
			}
		} catch (ParseException e) {
			e.printStackTrace();
		}
	}

}

附:SimpleDateFormat的格式:

   在实例化SimpleDateFormat时,采用"yyyy-MM-dd HH:mm:ss"这样的构造参数,可以对输出的格式进行设置。而字符串中的字母代表的含义如下:

  G 年代标志符
  y 年
  M 月
  d 日
  h 时 在上午或下午 (1~12)
  H 时 在一天中 (0~23)
  m 分
  s 秒
  S 毫秒
  E 星期
  D 一年中的第几天
  F 一月中第几个星期几
  w 一年中第几个星期
  W 一月中第几个星期
  a 上午 / 下午 标记符 
  k 时 在一天中 (1~24)
  K 时 在上午或下午 (0~11)
  z 时区

  除了上述具有实际含义的字母之外,还可以配合诸如:空格、:、-等进行格式化设置。

 

spring定时任务cronExpression的值(配置定时时间)格式说明:
一个cronExpression表达式有至少6个(也可能是7个)由空格分隔的时间元素。从左至右,这些元素的定义如下

 

1.秒(0–59)
2.分钟(0–59)
3.小时(0–23)
4.月份中的日期(1–31)
5.月份(1–12或JAN–DEC)
6.星期中的日期(1–7或SUN–SAT)
7.年份(1970–2099)
          秒 0-59 , - * / 
          分 0-59 , - * / 
          小时 0-23 , - * / 
          日期 1-31 , - * ? / L W C 
          月份 1-12 或者 JAN-DEC , - * / 
          星期 1-7 或者 SUN-SAT , - * ? / L C # 
          年(可选)留空, 1970-2099 , - * / 
          表达式意义 
          "0 0 12 * * ?" 每天中午12点触发 
"0 15 10 ? * *" 每天上午10:15触发 
"0 15 10 * * ?" 每天上午10:15触发 
"0 15 10 * * ? *" 每天上午10:15触发 
"0 15 10 * * ? 2005" 2005年的每天上午10:15触发 
"0 * 14 * * ?" 在每天下午2点到下午2:59期间的每1分钟触发 
"0 0/5 14 * * ?" 在每天下午2点到下午2:55期间的每5分钟触发 
"0 0/5 14,18 * * ?" 在每天下午2点到2:55期间和下午6点到6:55期间的每5分钟触发 
"0 0-5 14 * * ?" 在每天下午2点到下午2:05期间的每1分钟触发 
"0 10,44 14 ? 3 WED" 每年三月的星期三的下午2:10和2:44触发 
"0 15 10 ? * MON-FRI" 周一至周五的上午10:15触发 
"0 15 10 15 * ?" 每月15日上午10:15触发 
"0 15 10 L * ?" 每月最后一日的上午10:15触发 
"0 15 10 ? * 6L" 每月的最后一个星期五上午10:15触发 
"0 15 10 ? * 6L 2002-2005" 2002年至2005年的每月的最后一个星期五上午10:15触发 
"0 15 10 ? * 6#3" 每月的第三个星期五上午10:15触发 
每天早上6点 
0 6 * * * 
每两个小时 
0 */2 * * * 
晚上11点到早上7点之间每两个小时,早上八点 
0 23-7/2,8 * * * 
每个月的4号和每个礼拜的礼拜一到礼拜三的早上11点 
0 11 4 * 1-3 
1月1日早上4点 
0 4 1 1 *

 

 


 定时例子:

 

 

 

 

<!-- 定时任务 -->

	<!-- 配置定时任务的Bean-->
	<bean id="timeTask" class="com.hengbao.otp.task.TimeTask" >
		<property name="staticsSavePath" value="${statics.save.path}" />
	</bean>

	<!-- 配置定时任务具体执行的方法 -->


	<bean id="deleteStatis"
		class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">
		<property name="targetObject">
			<ref bean="timeTask" />
		</property>
		<!-- 指定定时任务bean中的方法名 -->
		<property name="targetMethod">
			<value>deleteStatics</value>
		</property>
		<property name="concurrent">
			<value>false</value>
		</property>
	</bean>


	<!-- 配置定时任务具体方法的执行时间 -->

	<bean id="deleteStatisStartupTrigger" class="org.springframework.scheduling.quartz.CronTriggerBean">
		<property name="jobDetail">
			<ref bean="deleteStatis" />
		</property>
		<!-- 每天 00:00:00秒执行 -->
		<property name="cronExpression" value=0 0 0 ? * *></property>
	</bean>


	<bean class="org.springframework.scheduling.quartz.SchedulerFactoryBean">
		<property name="triggers">
			<list>
				<ref local="deleteStatisStartupTrigger" />
			</list>
		</property>
	</bean>

 

 

 

 

spring 定时任务,时间格式

* 表示所有值. 例如:在分的字段上设置 "*",表示每一分钟都会触发。
? 表示不指定值。使用的场景为不需要关心当前设置这个字段的值。例如:要在每月的10号触发一个操作,但不关心是周几,所以需要周位置的那个字段设置 为"?" 具体设置为 0 0 0 10 * ?
- 表示区间。例如 在小时上设置 "10-12",表示 10,11,12点都会触发。
, 表示指定多个值,例如在周字段上设置 "MON,WED,FRI" 表示周一,周三和周五触发
/ 用于递增触发。如在秒上面设置"5/15" 表示从5秒开始,每增15秒触发(5,20,35,50)。 在月字段上设置'1/3'所示每月1号开始,每隔三天触发一次。
L 表示最后的意思。在日字段设置上,表示当月的最后一天(依据当前月份,如果是二月还会依据是否是润年[leap]), 在周字段上表示星期六,相当于"7"或"SAT"。如果在"L"前加上数字,则表示该数据的最后一个。例如在周字段上设置"6L"这样的格式,则表示“本 月最后一个星期五"
W 表示离指定日期的最近那个工作日(周一至周五). 例如在日字段上设置"15W",表示离每月15号最近的那个工作日触发。如果15号正好是周六,则找最近的周五(14号)触发, 如果15号是周未,则找最近的下周一(16号)触发.如果15号正好在工作日(周一至周五),则就在该天触发。如果指定格式为 "1W",它则表示每月1号往后最近的工作日触发。如果1号正是周六,则将在3号下周一触发。(注,"W"前只能设置具体的数字,不允许区间"-").

小提示'L'和 'W'可以一组合使用。如果在日字段上设置"LW",则表示在本月的最后一个工作日触发(一般指发工资 ) 
# 序号(表示每月的第几个周几),例如在周字段上设置"6#3"表示在每月的第三个周六.注意如果指定"#5",正好第五周没有周六,则不会触发该配置(用 在母亲节和父亲节再合适不过了) 
小提示周字段的设置,若使用英文字母是不区分大小写的 MON 与mon相同.
       
常用示例:

0 0 12 * * ?   每天12点触发   
0 15 10 ? * *   每天10点15分触发   
0 15 10 * * ?   每天10点15分触发   
0 15 10 * * ? *   每天10点15分触发   
0 15 10 * * ? 2005   2005年每天10点15分触发   
0 * 14 * * ?   每天下午的 2点到2点59分每分触发   
0 0/5 14 * * ?   每天下午的 2点到2点59分(整点开始,每隔5分触发)   
0 0/5 14,18 * * ?   每天下午的 2点到2点59分(整点开始,每隔5分触发)每天下午的 18点到18点59分(整点开始,每隔5分触发)   
0 0-5 14 * * ?   每天下午的 2点到2点05分每分触发   
0 10,44 14 ? 3 WED   3月分每周三下午的 2点10分和2点44分触发   
0 15 10 ? * MON-FRI   从周一到周五每天上午的10点15分触发   
0 15 10 15 * ?   每月15号上午10点15分触发   
0 15 10 L * ?   每月最后一天的10点15分触发   
0 15 10 ? * 6L   每月最后一周的星期五的10点15分触发   
0 15 10 ? * 6L 2002-2005   从2002年到2005年每月最后一周的星期五的10点15分触发   
0 15 10 ? * 6#3   每月的第三周的星期五开始触发   
0 0 12 1/5 * ?   每月的第一个中午开始每隔5天触发一次   
0 11 11 11 11 ?   每年的11月11号 11点11分触发(光棍节)   
 
你试试 0 0-55/5 14,18 * * ?

 

 

楼主这么辛苦,请扫一下楼主的支付宝红包推荐码吧,记得一定要消费掉哦。双赢哦。

1、打开支付宝首页搜索“8282987” 立即领红包。

2、扫码领红包。

领支付宝红包啦

标题。

 

 

 

 

 

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值