接口用来用户在泛普OA办公软件ThinkOne系统自由定义一些需要定时执行的操作
自定义定时器
一. 接口说明
该接口用来用户在泛普OA办公软件泛普OA系统系统自由定义一些需要定时执行的操作,它是由Quartz这一个开源的作业调度框架来实现;
该接口通过配置调度时间和自行开发调度动作来实现需要定时执行的任务。
该接口提供了两种调度方式
IntervalJob接口,此接口每隔一段时间执行一次(自己定义间隔时间)
CronJob接口,此接口在指定的时间点执行(自己定义时间点)
在开发调度动作需要实现泛普OA办公软件泛普OA系统提供的自定义动作接口。
二. 实现方法&步骤
1. 配置调度文件schedule.xml(该文件位于泛普OA办公软件泛普OA系统的WEB-INF/service/目录下)
<?xml version="1.0" encoding="GBK"?>
<module id="datasource" version="1.0.0">
<service-point id="job1" interface="OA.interfaces.schedule.IntervalJob">
<invoke-factory>
<construct class="MyIntervalJob ">
<set-service property="ds" service-id="datasource.dt1"/>
<set property="second" value="60"/>
</construct>
</invoke-factory>
</service-point>
<service-point id="job2" interface="OA.interfaces.schedule.CronJob">
<invoke-factory>
<construct class="MyCronJob ">
<set-service property="ds" service-id="datasource.dt2"/>
<set property="cronExpr" value="0 44 12 ? * MON-FRI"/>
</construct>
</invoke-factory>
</service-point>
上文中配置两个调度任务job1,job2,实现了两种调度策略,其中黑体部分是在配置每个调度时需要改变的内容;
注意:每次配置后需要重启OA服务方可生效;
2. 属性说明
Id:唯一标识该调度任务,无其他作用
service-id:上文定义的自定义数据源,如果任务执行的动作中需要和数据源中的数据库交付数据,需要设置该属性
class:该任务真正执行的操作,其中job1中MyIntervalJob必须继承OA.interfaces.schedule.IntervalJob,job2中MyCronJob必须继承OA.interfaces.schedule.CronJob;继承后需要实现的方法是其中的execute();
value:任务执行的频率,在JOB1中表示没60秒执行一次,在JOB2中表示每周一到周五12:44执行(JOB2的执行频率配置方式和一般LINUX操作系统的定时任务配置方式一致)
3. 在5.0及以上版本对于CronJob可以直接在进行可视化的配置
通过顶部菜单【设置中心】【外部接口设置】【配置计划任务接口】即可进入配置界面
点击右键【新建】即可创建一个新的【计划任务】
注意:该配置,不需要重启OA服务即可生效
4. 可视化配置属性说明
计划任务标识,即xml配置中的Id:唯一标识该调度任务,无其他作用
计划任务类,即xml配置中的class:该任务真正执行的操作,MyCronJo必须继承OA.interfaces.schedule.CronJob;继承后需要实现的方法是其中的execute();
定时时间,即xml配置中的value:任务执行的频率,表示每周一到周五12:44执行(执行频率配置方式和一般LINUX操作系统的定时任务配置方式一致)
5. 如何实现任务执行的操作
实现定时执行的操作,实际上就是实现OA.interfaces.schedule.BaseIntervalJob 或者OA.interfaces.schedule.BaseCronJob中的execute()方法
import OA.interfaces.schedule.BaseIntervalJob;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
/**
* IntervalJob示范代码,集成BaseIntervalJob,用自己的业务逻辑覆盖了execute()方法,实际使用中这里可以编写用户需要实现的代码
*/
public class MyIntervalJob extends BaseIntervalJob {
public void execute() {
//从数据源中获取连接
Connection conn = getDs().getConnection(); //此处是取得上文定义的数据源dt1,如果需要操作其他系统的数据才需要该定义
try {
//通过jdbc获取人数
PreparedStatement s = conn.prepareStatement("select count(*) as amount from hrmresource"); //此时假设在数据源dt1定义的数据库中有hrmresource表
ResultSet rs = s.executeQuery();
rs.next();
String amount = rs.getString("amount");
//输出到控制台
System.out.println("人数:" + amount);
//关闭记录集
rs.close();
//关闭statement
s.close();
} catch (Exception e) {
} finally {
try {
//关闭连接
conn.close();
} catch (Exception e) {
}
}
}
}
- 1OA办公管理软件可提供移动加密锁认证
- 2OA基二门户平台技术的业务协同管理平台
- 3泛普OA办公软件系统知识管理数据库设计实现大OA协同办公
- 4实现OA办公自动化系统的便捷化、集成化、现代化的功能
- 5泛普OA办公系统文档管理部分数据库相关字段属性的解释
- 6哪里有免费的OA办公软件或者网络版的源代码?泛普门户门户接口说明
- 7OA如何关联审批工作流的文档状态调整为正常或生效状态?
- 8泛普OA办公软件ThinkOne配置和异构系统的数据库的链接方式
- 9泛普OA办公软件知识文档部门的数据库表是对相关字段的属性的解释
- 10OA可以用任何方式或编程语言来读写数据库表
- 11OA系统数据读取和回写中间表实施
- 12泛普OA办公软件直接读取异构系统的结构型数据自动生成审批流程
- 13泛普OA软件主要数据结构-HR模块
- 14OA办公软件的维护权限是怎样实现的?
- 15办公自动化系统(OA)的数据库设计简介
- 16oa办公系统数据库设计
- 17协同OA软件记录未被读(表示还没有触发流程到OA)
- 18协同管理平台规划设计思路不原则
- 19为什么OA即时通讯只有内网能登录,外网登录不了?
- 20泛普OA办公软件ThinkOne系统的流程数据由表单组成,并取异构数据到流程表格
- 21协同软件的信息化规划的六化原则
- 22OA办公软件支持各种数据库种类
- 23接口用来用户在泛普OA办公软件ThinkOne系统自由定义一些需要定时执行的操作
- 24OA软件开发流程存储数据说明
- 25ERP数据库表单字段与OA软件数据库表单字段的关系
- 26OA办公系统中数据库客户联系日志提醒表
- 27协同OA软件对数据加密安全是怎样设计的?
- 28协同OA软件中数据库查询和处理语句(二)
- 29协同OA软件的中间表定义、存放位置
- 30泛普协同OA办公系统实现流程与NC业务数据流转过程中和异构系统数据交互