前提:业务流程复杂且流程频繁变更的,建议使用工作流;其他情况不建议使用。
activiti(v5.14),工作流引擎,基于jbpm。使用建模语言BPMN2.0进行定义。
工作流数据需要写入数据库,activiti(v5.14)支持的数据库有:db2、h2、mssql、mysql、oracle、postgres。
需要说明的是,activiti(v5.14)底层调用MyBatis来操作数据库。
activiti自带创建数据库表的SQL文件,执行即可。或者XML中设置通过创建ProcessEngine对象时检测有无activiti的表,如果没有则创建。(true)
--ge通用表,存储上传的图片及BPMN文件等。
--history历史表,流程执行过程的历史数据。
--id用户身份表,存储用户信息、组信息、用户和组的关系。
--re资源表,存储流程定义的信息、部署流程的信息。
--ru表,存储当前正在执行的流程相关信息,当前执行任务、流程变量等。
XML中需要配置数据源DataSource和ProcessEngineConfiguration。
使用步骤:
ProcessEngineConfiguration(加载xml)
--> ProcessEngine(单例管理!!!)
--> Activiti_Service(多个不同的service:RepositoryService,TaskService,IdentityService,FormService,RuntimeService,ManagementService,HistoryService)
概念①:流程定义、流程实例、任务、流程变量。
对比Java语言来说,流程定义就是类,流程实例就是类的实例化对象,任务则是类中的方法,流程变量则是方法的形参。
【】略微不同的是,流程中的任务是有顺序的,而类中的方法则可以随意调用。
所以可以存在多个流程定义(比如同时存在报销流程、采购流程等),每个流程定义又可以存在多个流程实例(多人同时报销,多人同时采购等)。
每个流程实例的任务列表(步骤)虽然一致,但进度彼此无关(例如甲刚申请报销,乙已经审核完毕等)。
同样的,每个流程实例的流程变量也彼此无关(例如报销金额)。
概念②:工作流引擎、各个Service。
activiti的核心就是流程引擎ProcessEngine。系统通过ProcessEngineConfiguration加载配置文件,并生成ProcessEngine,再通过ProcessEngine调用各个service。
如下图所示:
RepositoryService:资源Service,用于部署流程定义。
RuntimeService:运行Service,用于开启流程实例。
TaskService:任务Service,用于处理任务相关操作:完成任务等。
ManagementService:管理Service,用于(暂缺)。
IdentityService:身份Service,用于处理用户、用户组、用户和用户组的关系。
HistoryService:历史Service,用于查看历史记录。
FormService:自定义表单Service,用于处理自定义的表单数据。
流程变量通过Map对象存入,可以是基本类型,也可以是pojo(需要实现Serializable接口)。Map对象的Key就是流程变量的Key。
用法,UEl表达式:${ key > 5000 || key < 2000}
在工作流操作的表如报销单表中添加一个流程实例字段,使用该字段访问流程。
任务有任务人、候选人、候选组。 候选人/组,都可以有多个,以逗号分开。
建议候选组,这样就是组任务。用户只要隶属于用户组即可。
组用户查询组(待办)任务、拾取组(待办)任务-->个人待办任务、完成个人待办任务。
查询过程:创建查询、添加查询信息、查询、处理查询结果。
组任务和个人任务可以同时存在。
【】【】activiti没对拾取组任务的用户做限制,任何人都可以拾取。所以需要手动校验后再拾取!!!
通过IdentityService添加/删除用户组、用户、关系。
identityService.saveUser(user);
identityService.saveGroup(group);
identityService.deleteMembership(user, group); //
identityService.createMembership(user, group); //
小知识:
排他网关
实现流程分支,也叫异或(XOR)网关。
经过它的流程分支,只会有一条执行。如果分支条件都不满足,就会抛出异常,但流程并没有异常结束。
如果不使用排他网关,遇到分支都不符合条件的时候,流程会异常结束。【】【】