当前位置: 首页 > 工具软件 > Sprint.js > 使用案例 >

Sprint 定时器

谷梁涵忍
2023-12-01
 
  1. <bean id="buildHtml" parent="txProxyTemplate">      
  2.        <property name="target">      
  3.             <bean   class="com.njusc.gathd.gxh.templet.HtmlBuilder">      
  4.                   <property name="gxhUserService" ref="gxhUserService"></property>      
  5.             </bean>      
  6.        </property>      
  7.     </bean>      
  8.       
  9.     <bean id="methodInvokingJobDetail"      
  10.         class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">      
  11.         <property name="targetObject">      
  12.             <ref bean="buildHtml" />      
  13.         </property>      
  14.         <property name="targetMethod">      
  15.             <value>buildSendHtml</value>      
  16.         </property>      
  17.     </bean>      
  18.       
  19.     <bean id="cronTrigger"      
  20.         class="org.springframework.scheduling.quartz.CronTriggerBean">      
  21.         <property name="jobDetail">      
  22.             <ref bean="methodInvokingJobDetail" />      
  23.         </property>      
  24.         <property name="cronExpression">      
  25.             <value>0 26 16 * * ?</value>      
  26.         </property>      
  27.     </bean>      
  28.       
  29.     <bean        
  30.         class="org.springframework.scheduling.quartz.SchedulerFactoryBean">      
  31.         <property name="triggers">      
  32.             <list>      
  33.                 <ref local="cronTrigger" />      
  34.             </list>      
  35.         </property>      
  36.     </bean>  
  37. 一个cronExpression表达式有至少6个(也可能是7个)由空格分隔的时间元素。从左至右,这些元素的定义如下:

    1.秒(059

    2.分钟(059

    3.小时(023

    4.月份中的日期(131

    5.月份(112JANDEC

    6.星期中的日期(17SUNSAT

    7.年份(19702099

    0 0 10,14,16 * * ?

    每天上午10,下午2点和下午4

    0 0,15,30,45 * 1-10 * ?

    每月前10天每隔15分钟

    30 0 0 1 1 ? 2012

    201211日午夜过30秒时

    0 0 8-5 ? * MON-FRI

    每个工作日的工作时间

  38. 各个时间可用值如下:

     序号说明
     是否必填 允许填写的值允许的通配符
     1 秒 是 0-59    , - * /
     2 分 是 0-59
      , - * /
     3小时 是 0-23  , - * /
     4 日 是 1-31  , - * ? / L W
     5 月 是 1-12 or JAN-DEC  , - * /
     6 周 是 1-7 or SUN-SAT  , - * ? / L #
     7 年 否 empty 或 1970-2099 , - * /

    通配符说明:
    * 表示所有值. 例如:在分的字段上设置 "*",表示每一分钟都会触发。
    ? 表示不指定值。使用的场景为不需要关心当前设置这个字段的值。例如:要在每月的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相同.

  39. 例子:

    "0 0 12 * * ?" 每天中午十二点触发
    "0 15 10 ? * *"
    每天早上1015触发

    "0 15 10 * * ?"
    每天早上1015触发

    "0 15 10 * * ? *"
    每天早上1015触发

    "0 15 10 * * ? 2005" 2005
    年的每天早上1015触发

    "0 * 14 * * ?"
    每天从下午2点开始到259分每分钟一次触发

    "0 0/5 14 * * ?"
    每天从下午2点开始到255分结束每5分钟一次触发

    "0 0/5 14,18 * * ?"
    每天的下午2点至2556点至655分两个时间段内每5分钟一次触发

    "0 0-5 14 * * ?"
    每天14:0014:05每分钟一次触发

    "0 10,44 14 ? 3 WED"
    三月的每周三的14101444触发

    "0 15 10 ? * MON-FRI"
    每个周一、周二、周三、周四、周五的1015触发

    "0 15 10 15 * ?"
    每月15号的1015触发

    "0 15 10 L * ?"
    每月的最后一天的1015触发

    "0 15 10 ? * 6L"
    每月最后一个周五的1015

 类似资料: