一种基于Activiti的流程交互方法及系统与流程

文档序号:32817042发布日期:2023-01-04 03:45阅读:137来源:国知局
一种基于Activiti的流程交互方法及系统与流程
一种基于activiti的流程交互方法及系统
技术领域
1.本发明属于工作流技术领域,具体涉及一种基于activiti的流程交互方法及系统。


背景技术:

2.随着业务系统日趋复杂,目前单个流程模板局限性大,很难满足业务系统流程之间的处理逻辑,acitiviti是使用嵌入子流程流程元素《subprocess》内嵌在主流程元素《process》之内,只能在该流程中使用该子流程,外部是无法访问到的。这种子流程一般作为局部通用逻辑处理,或者因为特定业务需要,但是不能用于跨流程引擎的流程交互。


技术实现要素:

3.为解决现有技术中的不足,本发明提供一种基于activiti的流程交互方法及系统,实现了主流程可以启动单个或多个跨流程引擎的外部子流程的目的,使流程间的交互更加灵活,满足复杂的业务需求。
4.为达到上述目的,本发明所采用的技术方案是:
5.第一方面,提供一种基于activiti的流程交互方法,包括:基于流程设计器中配置的主流程启动子流程的方式,启动主流程和子流程;主流程流转过程中备份当前主流程节点信息;主流程通过多线程的方式启动多个子流程;在子流程端备份主流程信息;在主流程端记录子流程启动结果信息;子流程失败补发;其中,所述主流程是基于activiti的主流程;所述子流程是基于activiti的子流程,包括单个或多个跨流程引擎的外部子流程。
6.进一步地,流程设计器中配置的主流程启动子流程的方式,具体为:在流程设计器中,对子流程活动进行属性设置,包括:是否需要启动多个子流程、同步还是异步方式、当前流程引擎的流程系统url地址、跨流程引擎的子流程系统url地址。
7.进一步地,通过流程设计器的子流程活动图元设置当前流程图需要与远程在其他节点部署的基于activiti系统中的流程交互的属性信息,属性信息包括:子流程类型、调用方式、子流程名称、本地服务url、目标服务的url。
8.进一步地,主流程流转过程中备份当前主流程节点信息,具体为:当前主流程节点信息,包括主流程引擎地址、主流程流程实例id、主流程当前执行id、关联的业务表单数据;当前主流程节点信息保存到哈希表中,作为启动子流程的入参;主流程引擎地址在流程设计器中的子流程活动属性设置中有具体的url地址,获取该url地址,进行保存;主流程流程实例id和主流程当前执行id,即为当前流程的基本属性;关联的业务表单数据即为当前的主流程关联的表单中,需要与子流程表单属性进行同步的属性。
9.进一步地,主流程通过多线程的方式启动多个子流程,具体为:在流程设计器中的子流程活动属性中设置跨流程引擎的子流程系统url地址,多个地址之间用“;”分隔;创建设定数目的线程池,通过多线程调用启动远程子流程的方法,启动多个子流程,并获取每个子流程的启动结果。
10.进一步地,通过流程设计器设置的目标服务url地址的个数,通过多线程的方式启动外部子流程,由于需要等待线程的执行结果,所以选用future的线程任务模式,此任务模式实现了有返回值的callable接口,用于获取到该线程任务的返回值。
11.进一步地,在子流程端备份主流程信息,具体为:将主流程流转过程中备份的当前主流程节点信息,在子流程引擎系统中,以子流程能识别的变量名称,存储到子流程的标量表中。
12.进一步地,在主流程端记录子流程启动结果信息,具体为:获取主流程通过多线程的方式启动多个子流程的返回结果,统计启动外部子流程的成功的数目,以变量的形式记录启动成功的数量;在主流程通过多线程的方式启动多个子流程后,将当前主流程的执行id、流程编码、子流程的url地址、启动成功的子流程实例id、启动结果、报错信息记录到子流程实例表中。
13.进一步地,子流程失败补发,具体为:主流程通过多线程的方式启动多个子流程的过程中,如果存在失败的子流程需要补发,需要从在主流程端记录的子流程启动结果信息中取得当前主流程启动失败的所有子流程列表,对这些失败的子流程重新启动,如果成功,那么更新子流程实例表中对应记录的启动结果。
14.第二方面,提供一种基于activiti的流程交互系统,包括处理器和存储设备,所述存储设备中存储有多条指令,用于所述处理器加载并执行第一方面所述方法的步骤。
15.与现有技术相比,本发明所达到的有益效果:本发明通过基于流程设计器中配置的主流程启动子流程的方式,启动主流程和子流程;主流程流转过程中备份当前主流程节点信息;主流程通过多线程的方式启动多个子流程;在子流程端备份主流程信息;在主流程端记录子流程启动结果信息;子流程失败补发;其中,主流程是基于activiti的主流程;子流程是基于activiti的子流程,包括单个或多个跨流程引擎的外部子流程;实现了主流程可以启动单个或多个跨流程引擎的外部子流程的目的,使流程间的交互更加灵活,满足复杂的业务需求。
附图说明
16.图1是本发明实施例提供的一种基于activiti的流程交互方法的主要流程示意图;
17.图2是本发明实施例中流程设计器的子流程活动属性设置界面示意图;
18.图3本发明实施例提供的一种基于activiti的流程交互方法的详细流程示意图。
具体实施方式
19.下面结合附图对本发明作进一步描述。以下实施例仅用于更加清楚地说明本发明的技术方案,而不能以此来限制本发明的保护范围。
20.实施例一:
21.如图1~图3所示,一种基于activiti的流程交互方法,包括:基于流程设计器中配置的主流程启动子流程的方式,启动主流程和子流程;主流程流转过程中备份当前主流程节点信息;主流程通过多线程的方式启动多个子流程;在子流程端备份主流程信息;在主流程端记录子流程启动结果信息;子流程失败补发;其中,所述主流程是基于activiti的主流
程;所述子流程是基于activiti的子流程,包括单个或多个跨流程引擎的外部子流程。
22.本实施例通过采用在流程设计器中配置流程交互方式,实现主流程可以启动单个或多个跨流程引擎的外部子流程。所述的流程设计器即为流程的一种可视化界面,用于编排业务流程,对业务流程中的业务节点进行属性的设置;所述的主流程即为业务根据业务描述为若干活动之间的关系的主框架流程;所述的外部子流程即为主流程流转过程中需要与非本系统的另外一个流程进行交互,结束后可以返回子流程。
23.本实施例通过流程设计器配置子流程属性、发送多个外部子流程、发送失败重发,实现了主流程可以启动单个或多个跨流程引擎的外部子流程的目的,使流程间的交互更加灵活,满足复杂的业务需求。
24.图2为流程设计器的子流程活动属性设置界面示意图。如图2所示,子流程活动属性包括以下设置:
[0025][0026]
如图1、图3所示,一种基于activiti的流程交互方法,具体包括以下步骤。
[0027]
(1)基于流程设计器中配置的主流程启动子流程的方式,启动主流程和子流程。
[0028]
步骤s201解析子流程图元的属性信息。
[0029]
所述的解析子流程图元的属性信息,即为将子流程活动图元的相关属性设置转换为json对象,获取到相关key的值。
[0030]
在流程设计器中,对子流程活动进行属性设置,包括:是否需要启动多个子流程、同步还是异步方式、当前流程引擎的流程系统url地址、跨流程引擎的子流程系统url地址。
[0031]
步骤s202获取属性信息的主流程url地址、子流程url地址,获取当前主流程的流程实例id、执行id。
[0032]
(2)主流程流转过程中备份当前主流程节点信息。
[0033]
步骤s203获取当前子流程节点的配置信息,获取当前主流程的实例信息。
[0034]
所述的当前子流程节点的配置信息,即为子流程活动图元的主流程url地址、子流程url地址,所述的当前主流程的实例信息即为当前主流程的流程实例id、执行id。
[0035]
当前主流程节点信息,包括主流程引擎地址、主流程流程实例id、主流程当前执行id、关联的业务表单数据;当前主流程节点信息保存到哈希表中,作为启动子流程的入参。
[0036]
主流程引擎地址在所述的流程设计器中的子流程活动属性设置中有具体的url地址。
[0037]
主流程流程实例id和主流程当前执行id,即为当前流程的基本属性。
[0038]
关联的业务表单数据即为当前的主流程关联的表单中,有哪些属性需要与子流程表单属性进行同步。
[0039]
步骤s204、判断是否为外部多子流程。
[0040]
所述的判断是否为外部子流程,即为判断当前子流程活动图元的属性设置方式是否设置为外部子流程,并且判断是否设置了目标服务的url。
[0041]
(3)主流程通过多线程的方式启动多个子流程。
[0042]
步骤s205、根据配置的多子流程地址通过多线程的方式启动多个子流程。
[0043]
所述的主流程通过多线程的方式启动多个子流程,即为在所述的流程设计器中的子流程活动属性设置中的跨流程引擎的子流程系统url地址,多个地址之间用“;”分隔。
[0044]
创建设定数目的线程池,通过多线程调用启动远程子流程的方法,启动多个子流程。由于需要等待线程的执行结果,所以选用future的线程任务模式,此任务实现了有返回值的callable接口,因此可以获取到该线程任务的返回值。
[0045]
(4)在子流程端备份主流程信息;具体为:将主流程流转过程中备份的当前主流程节点信息,在子流程引擎系统中,以子流程能识别的变量名称,存储到子流程的标量表中。
[0046]
步骤s206、在子流程端将主流程的相关信息,存储到子流程变量表中。
[0047]
步骤s2061、生成的子流程可以根据流程图正常流转;
[0048]
步骤s2062、子流程结束后回到主流程。
[0049]
(5)在主流程端记录子流程启动结果信息。
[0050]
步骤s207在主流程端记录每个子流程线程启动后的结果信息,并将信息保存到数据库的子流程实例表中。
[0051]
所述的在主流程端记录子流程启动结果信息,即为:a、获取步骤(3)中通过多线程启动子流程的返回结果,统计启动外部子流程的成功的数目,以变量的形式记录启动成功的数量。b、在步骤(3)中以多线程的方式启动子流程后,将当前主流程的执行id、流程编码、子流程的url地址、启动成功的子流程实例id、启动结果、报错信息(如果启动失败)记录到子流程实例表pt_wf_hi_multisuproc中。
[0052]
(6)子流程失败补发。
[0053]
步骤s208、判断启动子流程时有无失败线程。
[0054]
根据主流程实例id找到活动类型为子流程活动的活动实例id,通过该活动实例id
获取当前的子流程活动的图元属性信息,并获取步骤s203中所需要的信息。
[0055]
步骤s209、从子流程实例表中取到当前流程相关的失败记录的url地址。
[0056]
根据此活动实例id在子流程实例表pt_wf_hi_multisuproc中找到所有启动失败记录的子流程地址addrs,将这些地址以“,”分隔,并保存到字符串中。
[0057]
步骤s210、以多线程的方式重新启动。
[0058]
重复s205的过程,以多线程的方式启动失败的子流程。
[0059]
步骤s211、更新子流程实例表中的信息。
[0060]
对失败的子流程启动完成后,获取到每个线程的完成结果更新子流程实例表pt_wf_hi_multisuproc。
[0061]
实施例二:
[0062]
基于实施例一所述的一种基于activiti的流程交互方法,本实施例提供一种基于activiti的流程交互系统,包括处理器和存储设备,所述存储设备中存储有多条指令,用于所述处理器加载并执行实施例一所述方法的步骤。
[0063]
本技术的实施例可提供为方法、系统、或计算机程序产品。因此,本技术可采用完全硬件实施例、完全软件实施例、或结合软件和硬件方面的实施例的形式。而且,本技术可采用在一个或多个其中包含有计算机可用程序代码的计算机可用存储介质(包括但不限于磁盘存储器、cd-rom、光学存储器等)上实施的计算机程序产品的形式。本技术实施例中的方案可以采用各种计算机语言实现,例如,面向对象的程序设计语言java和直译式脚本语言javascript等。
[0064]
本技术是参照根据本技术实施例的方法、设备(系统)、和计算机程序产品的流程图和/或方框图来描述的。应理解可由计算机程序指令实现流程图和/或方框图中的每一流程和/或方框、以及流程图和/或方框图中的流程和/或方框的结合。可提供这些计算机程序指令到通用计算机、专用计算机、嵌入式处理机或其他可编程数据处理设备的处理器以产生一个机器,使得通过计算机或其他可编程数据处理设备的处理器执行的指令产生用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的装置。
[0065]
这些计算机程序指令也可存储在能引导计算机或其他可编程数据处理设备以特定方式工作的计算机可读存储器中,使得存储在该计算机可读存储器中的指令产生包括指令装置的制造品,该指令装置实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能。
[0066]
这些计算机程序指令也可装载到计算机或其他可编程数据处理设备上,使得在计算机或其他可编程设备上执行一系列操作步骤以产生计算机实现的处理,从而在计算机或其他可编程设备上执行的指令提供用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的步骤。
[0067]
尽管已描述了本技术的优选实施例,但本领域内的技术人员一旦得知了基本创造性概念,则可对这些实施例作出另外的变更和修改。所以,所附权利要求意欲解释为包括优选实施例以及落入本技术范围的所有变更和修改。
[0068]
显然,本领域的技术人员可以对本技术进行各种改动和变型而不脱离本技术的精神和范围。这样,倘若本技术的这些修改和变型属于本技术权利要求及其等同技术的范围之内,则本技术也意图包含这些改动和变型在内。
当前第1页1 2 
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1