- 浏览: 698270 次
- 性别:
- 来自: 长沙
文章分类
- 全部博客 (364)
- quick start (57)
- bboss aop (43)
- bboss mvc (48)
- bboss persistent (96)
- bboss taglib (30)
- bboss event (10)
- bbossgroups (52)
- bboss (32)
- bboss会话共享 (17)
- bboss rpc (7)
- bboss 国际化 (5)
- bboss 序列化 (9)
- bboss cxf webservice (8)
- bboss hessian (3)
- bboss 安全认证SSO (15)
- bboss 工作流 (6)
- 平台 (18)
- bboss quartz (3)
- 杂谈 (5)
- 大数据 (1)
- bboss elastic (24)
- bboss http (1)
- bboss kafka (1)
- Elasticsearch Scroll和Slice Scroll查询API使用案例 (1)
最新评论
-
qianhao123:
...
采用gradle构建和发布bboss方法介绍 -
qianhao123:
[img][/img]
采用gradle构建和发布bboss方法介绍 -
yin_bp:
欢迎大家参与working
高性能elasticsearch ORM开发库使用介绍 -
qq641879434:
万分感谢
bboss 持久层sql xml配置文件编写和加载方法介绍 -
yin_bp:
qq641879434 写道怎么设置配置文件 可以查看执行的S ...
bboss 持久层sql xml配置文件编写和加载方法介绍
继扩展Activiti-5.12轻松实现流程节点间自由跳转和任意驳回/撤回功能之后,bboss最近对Activiti-5.12这个版本做了以下功能扩展:
1.如果人工任务节点没有设置处理人,则自动完成当前节点跳转到下一环节,如果对应人工任务节点(没有设置处理人的人工任务节点节点)设置了自动处理类(实现org.activiti.engine.delegate.JavaDelegate接口)参数,则会执行自动处理类的接口方法:
例如:流程中有a,b,c,d四个人工任务节点,其中b节点没有设置处理人,那么当a节点任务完成后,如果b节点没有设置自动处理类,那么直接忽略掉b,直接运行到c节点;如果b节点设置了自动处理类,那么流程引擎执行该处理类后再运行到c节点。
2.org.activiti.engine.impl.TaskServiceImpl组件增加一组带完成原因的completeTask接口,完成原因会直接填写到工作流的act_hi_task表的完成原因字段中。
例如:
public void completeWithDestReason(String taskId,String destinationTaskKey,String completeReason,String bussinessop,String bussinessRemark)
详情参考组件:
https://github.com/yin-bp/activiti-engine-5.12/blob/master/src/main/java/org/activiti/engine/impl/TaskServiceImpl.java
三个任务完成原因相关字段:
completeReason:流程引擎自身会填充的说明字段,业务程序也可自己填写这个字段,一般流程引擎会在字段中记录任务处理任意跳转,驳回等系统信息
bussinessop:由业务程序记录完成任务时的填写的业务操作码,可以填写,也可以不填写,流程引擎不会修改这个字段
bussinessRemark:由业务程序记录完成任务时填写的业务处理日志,可以填写,也可以不填写,流程引擎不会修改这个字段
同样也提供了一组带三个原因字段的驳回接口。
3.为了便于记录操作日志和提升系统性能,对流程活动历时表和任务历时表做了相应的扩展:
工作流任务表ACT_HI_ACTINST表中增加任务处理原因,任务业务操作类型,任务业务操作日志,签收时间,任务owner5个子段,同时ACT_HI_ACTINST记录任务kpi数据以及任务的节假日策略
工作流任务表ACT_HI_TASKINST表中增加任务业务操作类型,任务业务操作日志字段,同时ACT_HI_TASKINST记录任务kpi数据以及任务的节假日策略。
4.增加一组驳回接口,可以指定驳回的历史节点,驳回时可以指定驳回后,任务处理完毕可忽略后续节点直接跳转到驳回节点:
处理完毕后,按照正常的流程流转到驳回点,例如:流程中有a,b,c,d四个节点,由d节点驳回到a节点,当a处理完毕后,还要流转b,c两个节点再到达d.
处理完毕后,直接回到驳回点,例如:流程中有a,b,c,d四个节点,由d节点驳回到a节点,当a处理完毕后,直接流转到d节点,忽略b,c两个节点.
5.改造单实例人工任务节点(非Multi Instance的UseTask节点,设置多个处理人时只产生一个任务,这个任务只能被其中的一个人处理)逻辑,可以根据控制变量在流程实例开启和运行阶段改变单实例人工任务节点的处理节点为多实例任务节点(也就是说,如果单实例人工任务节点设置了多个处理人,会为每个人生成一个任务,此时,这个在建模时被定义为单实例人工任务的节点的行为已经和多实例人工任务节点的行为一致),这样不仅可以大大降低我们流程建模的复杂度(画多实例人工任务节点是比较复杂的),同时可以在流程实例运行过程中灵活控制单实例人工任务节点的行为(在设置了多个处理人时,可以根据控制变量改变其到底是按单实例任务跑,还是按多实例任务跑)。具体工作原理看下图:
6.改变流程变量的校验规则。在流程运行过程中,如果变量没有设置值时,不抛出Exception,只在log4j日志文件中输出相应的警告日志。
7.userTask 类型节点的activiti:assignee属性也可以设置多个处理人,以逗号分隔,例如:
<userTask id="usertask2" name="单实例" activiti:assignee="zhangsan,lisi,wangwu"></userTask>
改造版的bboss中要求流程处理人变量必须是以下命名格式:
活动id+_+users
例如:
<userTask id="usertask2" name="单实例" activiti:assignee="${usertask2_users}"></userTask>
8.单实例人工任务节点,当只设置了一个处理人时,不再需要签收任务,任务直接被assignee个指定的这个人
9.在流程引擎级别记录驳回操作,撤销操作,驳回后回到驳回点操作,任意跳转操作日志,以便在处理任务时进行相应的处理操作
常量:
org.activiti.engine.TaskService定义了四个常量与上述四个操作对应
10.定义了扩展归档机制,当流程实例结束时,用户可以在归档接口方法中将需要归档的实例运行时数据进行归档,流程引擎默认对流程引擎级别驳回操作、撤销操作、驳回后回到驳回点操作、任意跳转操作日志进行归档。
归档组件必须实现接口方法:
在流程引擎配置文件中增加以下注入配置即可:
11.由于我们可以直接在任务历史表和活动历史表中记录任务和活动处理日志和业务处理日志和业务处理操作,为了解决mysql下这些处理日志的排序问题,为ACT_HI_ACTINST 和ACT_HI_TASKINST 两个表分别增加了以下long形的排序时间字段:START_TIME_LONG, END_TIME_LONG
12.提供抄送/通知任务类型,支持抄送到人和部门,抄送任务不影响流程的正常流转,比如最后一个任务节点被设置为抄送任务节点后,抄送任务产生后流程立即结束,但是抄送任务仍然存在,知道相关人员阅读完抄送任务后结束
13.可自动跳过相同处理人的节点,为了便于业务逻辑的处理,可以在自动过的时候指定自动业务处理回调类。
14.最新的bboss版activiti 5.12对流程引擎数据库做了相应的调整,如果要升级需要执行的sql脚本如下:
mysql:
oracle:
15.最新的bboss版activiti 5.12下载地址:
https://github.com/yin-bp/activiti-engine-5.12
1.如果人工任务节点没有设置处理人,则自动完成当前节点跳转到下一环节,如果对应人工任务节点(没有设置处理人的人工任务节点节点)设置了自动处理类(实现org.activiti.engine.delegate.JavaDelegate接口)参数,则会执行自动处理类的接口方法:
void execute(DelegateExecution execution) throws Exception;.
例如:流程中有a,b,c,d四个人工任务节点,其中b节点没有设置处理人,那么当a节点任务完成后,如果b节点没有设置自动处理类,那么直接忽略掉b,直接运行到c节点;如果b节点设置了自动处理类,那么流程引擎执行该处理类后再运行到c节点。
2.org.activiti.engine.impl.TaskServiceImpl组件增加一组带完成原因的completeTask接口,完成原因会直接填写到工作流的act_hi_task表的完成原因字段中。
例如:
public void completeWithDestReason(String taskId,String destinationTaskKey,String completeReason,String bussinessop,String bussinessRemark)
详情参考组件:
https://github.com/yin-bp/activiti-engine-5.12/blob/master/src/main/java/org/activiti/engine/impl/TaskServiceImpl.java
三个任务完成原因相关字段:
completeReason:流程引擎自身会填充的说明字段,业务程序也可自己填写这个字段,一般流程引擎会在字段中记录任务处理任意跳转,驳回等系统信息
bussinessop:由业务程序记录完成任务时的填写的业务操作码,可以填写,也可以不填写,流程引擎不会修改这个字段
bussinessRemark:由业务程序记录完成任务时填写的业务处理日志,可以填写,也可以不填写,流程引擎不会修改这个字段
同样也提供了一组带三个原因字段的驳回接口。
3.为了便于记录操作日志和提升系统性能,对流程活动历时表和任务历时表做了相应的扩展:
工作流任务表ACT_HI_ACTINST表中增加任务处理原因,任务业务操作类型,任务业务操作日志,签收时间,任务owner5个子段,同时ACT_HI_ACTINST记录任务kpi数据以及任务的节假日策略
工作流任务表ACT_HI_TASKINST表中增加任务业务操作类型,任务业务操作日志字段,同时ACT_HI_TASKINST记录任务kpi数据以及任务的节假日策略。
4.增加一组驳回接口,可以指定驳回的历史节点,驳回时可以指定驳回后,任务处理完毕可忽略后续节点直接跳转到驳回节点:
public boolean rejecttoTask(String taskId, Map<String, Object> variables,String desttaskkey )//处理完毕后,按照正常的流程流转到驳回点
处理完毕后,按照正常的流程流转到驳回点,例如:流程中有a,b,c,d四个节点,由d节点驳回到a节点,当a处理完毕后,还要流转b,c两个节点再到达d.
public boolean rejecttoTask(String taskId, Map<String, Object> variables, String desttaskkey, boolean returntoreject)//增加了处理任务后直接回到驳回点的控制变量
处理完毕后,直接回到驳回点,例如:流程中有a,b,c,d四个节点,由d节点驳回到a节点,当a处理完毕后,直接流转到d节点,忽略b,c两个节点.
5.改造单实例人工任务节点(非Multi Instance的UseTask节点,设置多个处理人时只产生一个任务,这个任务只能被其中的一个人处理)逻辑,可以根据控制变量在流程实例开启和运行阶段改变单实例人工任务节点的处理节点为多实例任务节点(也就是说,如果单实例人工任务节点设置了多个处理人,会为每个人生成一个任务,此时,这个在建模时被定义为单实例人工任务的节点的行为已经和多实例人工任务节点的行为一致),这样不仅可以大大降低我们流程建模的复杂度(画多实例人工任务节点是比较复杂的),同时可以在流程实例运行过程中灵活控制单实例人工任务节点的行为(在设置了多个处理人时,可以根据控制变量改变其到底是按单实例任务跑,还是按多实例任务跑)。具体工作原理看下图:
6.改变流程变量的校验规则。在流程运行过程中,如果变量没有设置值时,不抛出Exception,只在log4j日志文件中输出相应的警告日志。
7.userTask 类型节点的activiti:assignee属性也可以设置多个处理人,以逗号分隔,例如:
<userTask id="usertask2" name="单实例" activiti:assignee="zhangsan,lisi,wangwu"></userTask>
改造版的bboss中要求流程处理人变量必须是以下命名格式:
活动id+_+users
例如:
<userTask id="usertask2" name="单实例" activiti:assignee="${usertask2_users}"></userTask>
8.单实例人工任务节点,当只设置了一个处理人时,不再需要签收任务,任务直接被assignee个指定的这个人
9.在流程引擎级别记录驳回操作,撤销操作,驳回后回到驳回点操作,任意跳转操作日志,以便在处理任务时进行相应的处理操作
常量:
org.activiti.engine.TaskService定义了四个常量与上述四个操作对应
public static final int op_rejected = 3;//驳回操作 public static final int op_withdraw = 1;//撤销操作 public static final int op_jump = 2;//任意跳转操作 public static final int op_returntorejected = 0;//驳回后回到驳回点操作
10.定义了扩展归档机制,当流程实例结束时,用户可以在归档接口方法中将需要归档的实例运行时数据进行归档,流程引擎默认对流程引擎级别驳回操作、撤销操作、驳回后回到驳回点操作、任意跳转操作日志进行归档。
归档组件必须实现接口方法:
package org.activiti.engine /** * 工作流 * @author yinbp * */ public interface KPIService { //计算任务超时时间和任务预警时间接口方法 public KPI buildKPI(DelegateExecution execution,Collection<String> candiates,Date taskCreateTime) throws ActivitiException; //获取任务处理节点控制变量方法 public ControlParam getControlParam(DelegateExecution currentexecution,String taskKey) throws ActivitiException; //获取任务处理节点控制变量方法 public ControlParam getControlParam(String processInstanceId,String activieKey) throws ActivitiException; /** * 流程实例结束后,对实例相关的外围扩展信息实时归档操作 * @param currentexecution * @param processInstanceID * @throws ActivitiException */ public void archiveProcessRuntimedata(DelegateExecution currentexecution,String processInstanceID) throws ActivitiException; }
在流程引擎配置文件中增加以下注入配置即可:
<property name="processEngineConfiguration" class="org.activiti.engine.impl.cfg.StandaloneProcessEngineConfiguration"> .... <property name="KPIService" class="com.bboss.workflow.service.impl.PlatformKPIServiceImpl"/> .... </property>
11.由于我们可以直接在任务历史表和活动历史表中记录任务和活动处理日志和业务处理日志和业务处理操作,为了解决mysql下这些处理日志的排序问题,为ACT_HI_ACTINST 和ACT_HI_TASKINST 两个表分别增加了以下long形的排序时间字段:START_TIME_LONG, END_TIME_LONG
12.提供抄送/通知任务类型,支持抄送到人和部门,抄送任务不影响流程的正常流转,比如最后一个任务节点被设置为抄送任务节点后,抄送任务产生后流程立即结束,但是抄送任务仍然存在,知道相关人员阅读完抄送任务后结束
13.可自动跳过相同处理人的节点,为了便于业务逻辑的处理,可以在自动过的时候指定自动业务处理回调类。
14.最新的bboss版activiti 5.12对流程引擎数据库做了相应的调整,如果要升级需要执行的sql脚本如下:
mysql:
-- Create table create table td_wf_rejectlog ( newtaskid varchar(64) not null, rejecttaskid varchar(64) not null, rejectnode varchar(100) not null, primary key (newtaskid) ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE utf8_bin; ALTER TABLE ACT_RU_TASK ADD COLUMN DURATION_NODE decimal(19) NULL DEFAULT 0; ALTER TABLE ACT_RU_TASK ADD COLUMN ADVANCESEND decimal(1) NULL DEFAULT 0; ALTER TABLE ACT_RU_TASK ADD COLUMN OVERTIMESEND decimal(1) NULL DEFAULT 0; ALTER TABLE ACT_RU_TASK ADD COLUMN (ALERTTIME TIMESTAMP NULL DEFAULT NULL); ALTER TABLE ACT_RU_TASK ADD COLUMN (OVERTIME TIMESTAMP NULL DEFAULT NULL); ALTER TABLE ACT_HI_ACTINST ADD COLUMN DURATION_NODE decimal(19) NULL DEFAULT 0; ALTER TABLE ACT_HI_ACTINST ADD COLUMN ADVANCESEND decimal(1) NULL DEFAULT 0; ALTER TABLE ACT_HI_ACTINST ADD COLUMN OVERTIMESEND decimal(1) NULL DEFAULT 0; ALTER TABLE ACT_HI_ACTINST ADD COLUMN (ALERTTIME TIMESTAMP NULL DEFAULT NULL); ALTER TABLE ACT_HI_ACTINST ADD COLUMN (OVERTIME TIMESTAMP NULL DEFAULT NULL); ALTER TABLE ACT_HI_TASKINST ADD COLUMN DURATION_NODE decimal(19) NULL DEFAULT 0; ALTER TABLE ACT_HI_TASKINST ADD COLUMN ADVANCESEND decimal(1) NULL DEFAULT 0; ALTER TABLE ACT_HI_TASKINST ADD COLUMN OVERTIMESEND decimal(1) NULL DEFAULT 0; ALTER TABLE ACT_HI_TASKINST ADD COLUMN (ALERTTIME TIMESTAMP NULL DEFAULT NULL); ALTER TABLE ACT_HI_TASKINST ADD COLUMN (OVERTIME TIMESTAMP NULL DEFAULT NULL); ALTER TABLE ACT_HI_ACTINST ADD COLUMN (NOTICERATE decimal(8)); ALTER TABLE ACT_HI_TASKINST ADD COLUMN (NOTICERATE decimal(8)); ALTER TABLE ACT_RU_TASK ADD COLUMN (NOTICERATE decimal(8)); ALTER TABLE ACT_HI_ACTINST ADD COLUMN (IS_CONTAIN_HOLIDAY decimal(1)); ALTER TABLE ACT_HI_TASKINST ADD COLUMN (IS_CONTAIN_HOLIDAY decimal(1)); ALTER TABLE ACT_RU_TASK ADD COLUMN (IS_CONTAIN_HOLIDAY decimal(1) ); ALTER TABLE ACT_HI_ACTINST ADD COLUMN IS_AUTO_COMPLETE decimal(1) NULL DEFAULT 0; ALTER TABLE ACT_HI_ACTINST ADD COLUMN (AUTO_HANDLER varchar(255)); ALTER TABLE ACT_HI_TASKINST ADD COLUMN (BUSSINESS_OP varchar(255)); ALTER TABLE ACT_HI_TASKINST ADD COLUMN (BUSSINESS_REMARK varchar(2000)); ALTER TABLE ACT_HI_ACTINST ADD COLUMN (BUSSINESS_OP VARCHAR(255)); ALTER TABLE ACT_HI_ACTINST ADD COLUMN (BUSSINESS_REMARK VARCHAR(2000)); ALTER TABLE ACT_HI_ACTINST ADD COLUMN (DELETE_REASON_ VARCHAR(2000)); ALTER TABLE ACT_HI_ACTINST ADD COLUMN (OWNER_ VARCHAR(255)); ALTER TABLE ACT_HI_ACTINST ADD COLUMN (CLAIM_TIME_ TIMESTAMP NULL DEFAULT NULL); ALTER TABLE td_wf_rejectlog ADD COLUMN (optype decimal(1) NULL DEFAULT 0); ALTER TABLE TD_WF_REJECTLOG ADD (PROCESS_ID VARCHAR(100)); create table td_wf_hi_rejectlog ( newtaskid varchar(64) not null, rejecttaskid varchar(64) not null, rejectnode varchar(100) not null, BACKUPTIME TIMESTAMP NULL DEFAULT NULL, optype decimal(1) NULL DEFAULT 0, PROCESS_ID VARCHAR(100), primary key (newtaskid) ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE utf8_bin; ALTER TABLE ACT_HI_ACTINST ADD COLUMN (START_TIME_LONG bigint ); ALTER TABLE ACT_HI_ACTINST ADD COLUMN (END_TIME_LONG bigint ); ALTER TABLE ACT_HI_TASKINST ADD COLUMN (START_TIME_LONG bigint ); ALTER TABLE ACT_HI_TASKINST ADD COLUMN (END_TIME_LONG bigint );
oracle:
-- Create table create table td_wf_rejectlog ( newtaskid nvarchar2(64), rejecttaskid nvarchar2(64), rejectnode nvarchar2(100) ) ; -- Create/Recreate primary, unique and foreign key constraints alter table td_wf_rejectlog add constraint rejectlog_pk primary key (NEWTASKID); --流程引擎扩展表字段 ALTER TABLE ACT_RU_TASK ADD (DURATION_NODE NUMBER(19)); ALTER TABLE ACT_RU_TASK ADD (ADVANCESEND NUMBER(1) DEFAULT 0); ALTER TABLE ACT_RU_TASK ADD (OVERTIMESEND NUMBER(1)); ALTER TABLE ACT_RU_TASK MODIFY(DURATION_NODE DEFAULT 0); ALTER TABLE ACT_RU_TASK MODIFY(OVERTIMESEND DEFAULT 0); ALTER TABLE ACT_RU_TASK ADD (ALERTTIME TIMESTAMP(7)); ALTER TABLE ACT_RU_TASK ADD (OVERTIME TIMESTAMP(7)); ALTER TABLE ACT_HI_ACTINST ADD (DURATION_NODE NUMBER(19)); ALTER TABLE ACT_HI_ACTINST ADD (ADVANCESEND NUMBER(1) DEFAULT 0); ALTER TABLE ACT_HI_ACTINST ADD (OVERTIMESEND NUMBER(1)); ALTER TABLE ACT_HI_ACTINST MODIFY(DURATION_NODE DEFAULT 0); ALTER TABLE ACT_HI_ACTINST MODIFY(OVERTIMESEND DEFAULT 0); ALTER TABLE ACT_HI_ACTINST ADD (ALERTTIME TIMESTAMP(7)); ALTER TABLE ACT_HI_ACTINST ADD (OVERTIME TIMESTAMP(7)); ---------------------------------------------------- ALTER TABLE ACT_HI_TASKINST ADD (DURATION_NODE NUMBER(19)); ALTER TABLE ACT_HI_TASKINST ADD (ADVANCESEND NUMBER(1) DEFAULT 0); ALTER TABLE ACT_HI_TASKINST ADD (OVERTIMESEND NUMBER(1)); ALTER TABLE ACT_HI_TASKINST MODIFY(DURATION_NODE DEFAULT 0); ALTER TABLE ACT_HI_TASKINST MODIFY(OVERTIMESEND DEFAULT 0); ALTER TABLE ACT_HI_TASKINST ADD (ALERTTIME TIMESTAMP(7)); ALTER TABLE ACT_HI_TASKINST ADD (OVERTIME TIMESTAMP(7)); --------------------- ALTER TABLE ACT_HI_ACTINST ADD (NOTICERATE NUMBER(8)); ALTER TABLE ACT_HI_TASKINST ADD (NOTICERATE NUMBER(8)); ALTER TABLE ACT_RU_TASK ADD (NOTICERATE NUMBER(8)); ------------------------- ALTER TABLE ACT_HI_ACTINST ADD (IS_CONTAIN_HOLIDAY NUMBER(1)); ALTER TABLE ACT_HI_TASKINST ADD (IS_CONTAIN_HOLIDAY NUMBER(1)); ALTER TABLE ACT_RU_TASK ADD (IS_CONTAIN_HOLIDAY NUMBER(1) ); ALTER TABLE ACT_HI_ACTINST ADD (IS_AUTO_COMPLETE NUMBER(1) DEFAULT 0); ALTER TABLE ACT_HI_ACTINST ADD (AUTO_HANDLER NVARCHAR2(255)); ALTER TABLE ACT_HI_TASKINST ADD (BUSSINESS_OP NVARCHAR2(255)); ALTER TABLE ACT_HI_TASKINST ADD (BUSSINESS_REMARK NVARCHAR2(2000)); ALTER TABLE ACT_HI_ACTINST ADD (BUSSINESS_OP NVARCHAR2(255)); ALTER TABLE ACT_HI_ACTINST ADD (BUSSINESS_REMARK NVARCHAR2(2000)); ALTER TABLE ACT_HI_ACTINST ADD (DELETE_REASON_ NVARCHAR2(2000)); ALTER TABLE ACT_HI_ACTINST ADD (OWNER_ NVARCHAR2(255)); ALTER TABLE ACT_HI_ACTINST ADD (CLAIM_TIME_ TIMESTAMP(6)); ALTER TABLE td_wf_rejectlog ADD (optype NUMBER(1) DEFAULT 0); ALTER TABLE TD_WF_REJECTLOG ADD (PROCESS_ID NVARCHAR2(100)); -- Create table create table td_wf_hi_rejectlog ( newtaskid nvarchar2(64), rejecttaskid nvarchar2(64), rejectnode nvarchar2(100), BACKUPTIME TIMESTAMP(6), optype NUMBER(1) DEFAULT 0, PROCESS_ID NVARCHAR2(100) ) ; -- Create/Recreate primary, unique and foreign key constraints alter table td_wf_hi_rejectlog add constraint hi_rejectlog_pk primary key (NEWTASKID); ALTER TABLE ACT_HI_ACTINST ADD (START_TIME_LONG NUMBER(19) ); ALTER TABLE ACT_HI_ACTINST ADD (END_TIME_LONG NUMBER(19) ); ALTER TABLE ACT_HI_TASKINST ADD (START_TIME_LONG NUMBER(19) ); ALTER TABLE ACT_HI_TASKINST ADD (END_TIME_LONG NUMBER(19) );
15.最新的bboss版activiti 5.12下载地址:
https://github.com/yin-bp/activiti-engine-5.12
发表评论
-
bboss ioc快速入门教程
2017-08-13 11:28 1281bboss是一个非常不错的ioc框架,功能类似于spr ... -
bboss kafka组件使用介绍
2017-07-22 14:03 1356bboss kafka组件使用介绍 本文使用的实例对应的gra ... -
bboss log4j滚动日志文件扩展插件使用介绍
2017-06-25 11:05 1450bboss扩展了log4j滚动切割文件插件org.apache ... -
bboss redis组件使用实例
2017-03-04 16:57 1189在工程中导入bboss redis组件 gradle comp ... -
bboss 与ecipse gradle buildship插件结合使用方法
2017-02-23 09:48 1201本文介绍bboss 与ecipse gradle builds ... -
如何快速高效地开发和调试基于gradle管理的web应用
2016-09-28 23:39 1479本文探讨如何高效快速地开发和调试基于gradle管理的web应 ... -
bboss wordpdf构建部署介绍
2016-09-02 15:47 572bboss wordpdf构建部署介绍 下载 源码下载地址: ... -
bboss gradle工程导入eclipse介绍
2016-07-24 14:01 2942bboss gradle工程导入eclipse介绍(本文适用于 ... -
采用gradle构建和发布bboss方法介绍
2016-05-01 23:23 4718采用gradle构建和发布bboss版本及从maven中央库下 ... -
bboss文件缓存组件FileContentCache介绍
2016-02-27 15:23 708bboss文件缓存组件FileContentCache介绍 ... -
bboss自动代码生成工具使用指南
2015-11-15 21:09 10154本文介绍bboss自动代码生成工具使用方法 工具在线试用: ... -
bboss应用程序运行容器使用介绍
2015-06-22 16:15 1943bboss微服务运行容器使 ... -
bboss框架配置监控介绍
2015-01-12 14:26 1678bboss框架配置监控介绍 ... -
bboss开发、模块工程目录结构及功能说明
2014-10-15 19:46 4919基于bboss开发项目说明 ... -
bboss最佳实践gradle工程清单及其作用介绍
2014-09-27 09:13 2319基于bboss开发项目说明 ... -
bboss跨站攻击白名单和脚本攻击防火墙配置
2014-08-01 09:56 1112本文详细介绍bboss跨站攻击白名单和跨站脚本攻击防火墙配置 ... -
bboss会话共享demo使用指南
2014-07-01 17:57 5583为了方便应用系统集成b ... -
bboss序列化cglib代理对象方法介绍
2014-06-22 15:14 1184本文介绍bboss序列化cglib代理对象方法。经过cglib ... -
bboss session共享架构及特点
2014-06-14 12:33 6440bboss会话共享架构 bboss session共 ... -
bboss自定义类对象序列化机制介绍
2014-05-26 23:32 1476bboss自定义类对象序列 ...
相关推荐
Activiti 是一个轻量级、高效且可扩展的工作流引擎,它支持BPMN 2.0标准,可以处理复杂的工作流程和业务规则。Activiti 提供了一个强大的API和直观的模型定义语言(BPMN),使得开发者能够快速构建和部署业务流程...
这个压缩包包含了 Activiti 的不同版本,包括 5.12、5.14 和 5.15,这些都是 Java 开发人员在构建企业级应用时可能会用到的组件。每个版本的 Activiti 设计师都是一个图形化的流程建模工具,帮助用户设计和调试工作...
抄送和通知任务改造:AtomicOperationTransitionDestroyScope流程自动过,没有设置处理人时,根据配置执行业务处理回调函数,然后自动往前执行流程如果流程任务当前处理环境和下一个任务的处理人相同,则直接跳过...
activiti三种表单的demo实现 运行方式: 1,修改连接的数据库 2,sql文件在resources\sql下 3,访问地址http://localhost:8080/activiti-demo/main/index
Activiti5.22.0扩展支持达梦数据库
activiti兼容达梦数据库,附件中是打包好的支持国产数据库达梦的activiti-engine-5.22.0.jar, 工作需要把数据库迁移到达梦数据库,发现activiti不支持达梦,花了几个小时修改了源码,并调试通过。 具体修改的类是: ...
为了使activiti7工作流支持达梦数据库,修改源码扩展的时候,有很多编译不通过的地方,自己修改了一下,activiti-engine-7.0.0.Beta2.jar
activiti-bpmn-converter-5.12
【通用eclipse版Activiti插件】是一款专为开发者设计的工具,旨在简化在Eclipse或MyEclipse环境中集成和使用Activiti工作流引擎的过程。Activiti是一个开源的业务流程管理(BPM)和工作流系统,它允许开发人员轻松地...
Activiti 适配达梦数据库教程 activiti 是一个开源的 Workflow 和 BPM system,它提供了强大的工作流引擎和业务流程管理功能。然而,activiti 默认支持的数据库只有 MySQL、 PostgreSQL、Oracle 等少数几种,而达梦...
【通用eclipse版activiti5.18插件】是一个专为开发人员设计的扩展工具,它使得在Eclipse集成开发环境中(IDE)使用Activiti工作流引擎变得更加便捷。Activiti是一个开源的业务流程管理(BPM)和工作流系统,它基于...
8. Activiti的扩展与定制:包括自定义行为(如定时器、监听器)、表单(Form)和任务服务的扩展,以及流程引擎的日志、监控和调试。 9. 实战案例分析:书中通过一系列的实际案例,如请假审批流程、采购流程等,展示...
本篇将详细探讨"activiti动态创建路径"这一主题,以及如何借助源码和工具实现这一功能。 首先,理解"动态创建路径"在Activiti中的含义。在业务流程设计中,路径指的是流程实例在执行过程中的流转路径,如审批环节的...
6. **扩展性**:除了基本的流程设计,Activiti Designer还允许通过自定义表单和事件处理器等来扩展功能,满足复杂业务需求。 7. **文档生成**:设计师可以导出流程图为PNG或其他图像格式,方便在报告或文档中使用。...
Activiti将是一种轻量级,可嵌入的BPM引擎,而且还设计适用于可扩展的云架构。 Activiti将提供宽松的Apache许可2.0,以便这个项目可以广泛被使用,同时促进Activiti BPM引擎和BPMN 2.0的匹配,该项目现正由OMG通过...
5. **流程实例的动态修改**:在 Activiti7.0 中,你可以动态修改运行中的流程实例,无需停止或重启服务,提高了灵活性和适应性。 6. **增强的监控和日志记录**:新的版本提供了更强大的监控工具和日志记录,帮助...
Activiti Modeler是一款流行的工作流建模工具,用于设计和管理Activiti流程定义。它基于BPMN(Business Process Modeling Notation)标准,提供了一种图形化的用户界面,使得业务人员和技术人员能够协同设计和理解...
这个压缩包提供的解决方案是扩展了Activiti的流程设计器,将人员和角色组的输入方式改为选择方式,这意味着设计者可以通过下拉菜单或类似的交互方式来选取参与者,极大地提高了设计效率和准确性。 实现这一功能的...
总的来说,Activiti 5.4 用户指南-中文版是了解和掌握 Activiti 的重要资源,它将引导用户逐步了解如何使用 Activiti 设计、部署和管理业务流程,从而提升企业的业务自动化水平和运营效率。通过深入学习本指南,你...
activiti6.0 用户指南中文版activiti6.0 用户指南中文版activiti6.0 用户指南中文版