CN112181378B - 业务流程的实现方法及装置 - Google Patents
业务流程的实现方法及装置 Download PDFInfo
- Publication number
- CN112181378B CN112181378B CN202011104127.XA CN202011104127A CN112181378B CN 112181378 B CN112181378 B CN 112181378B CN 202011104127 A CN202011104127 A CN 202011104127A CN 112181378 B CN112181378 B CN 112181378B
- Authority
- CN
- China
- Prior art keywords
- node
- processor
- function
- function processor
- determining
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Active
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F8/00—Arrangements for software engineering
- G06F8/20—Software design
- G06F8/24—Object-oriented
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F8/00—Arrangements for software engineering
- G06F8/30—Creation or generation of source code
- G06F8/38—Creation or generation of source code for implementing user interfaces
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F8/00—Arrangements for software engineering
- G06F8/70—Software maintenance or management
Landscapes
- Engineering & Computer Science (AREA)
- Software Systems (AREA)
- General Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Human Computer Interaction (AREA)
- Management, Administration, Business Operations System, And Electronic Commerce (AREA)
Abstract
本申请实施例公开了业务流程的实现方法及装置,用以解决现有的业务流程实现复杂、可读性差的问题。所述方法包括:获取目标业务的业务流程包含的各个功能处理器在业务流程中的节点特性;各功能处理器对应各自的节点特性;节点特性包括流程节点、接入节点、普通节点、结束节点、条件节点中的至少一项;根据节点特性,确定业务流程对应的功能处理器上下文链路;功能处理器上下文链路中包含各个功能处理器;确定功能处理器上下文链路为业务流程的流程链路。该技术方案使得开发人员在实现各业务的业务流程时,仅关心如何实现各功能处理器即可,无需关心各功能处理器之间的衔接,降低了业务开发的复杂性,提升了业务流程的可读性,且节约了开发成本。
Description
技术领域
本申请涉及业务技术领域,尤其涉及一种业务流程的实现方法及装置。
背景技术
随着业务的不断应用发展,业务流程也需要迭代更新。然而,目前实现的业务流程中的各节点对应的代码逻辑复杂,堆叠杂乱,且各节点之间属于强耦合关系,导致业务流程的可读性及可扩展性较差,因此,即便需要对一个流程节点进行调整,也需要对业务流程进行整体变更。而业务流程的整体变更意味着需要重新开发或者重构程序,变更成本高昂,此外,目前实现的业务流程较复杂,在对业务流程进行变更时,开发人员入手也非常困难。
发明内容
本申请实施例的目的是提供一种业务流程的实现方法及装置,用以解决现有的业务流程实现复杂、可读性差的问题。
为解决上述技术问题,本申请实施例是这样实现的:
一方面,本申请实施例提供一种业务流程的实现方法,包括:
获取目标业务的业务流程包含的各个功能处理器在所述业务流程中的节点特性;各所述功能处理器对应各自的节点特性;所述节点特性包括流程节点、接入节点、普通节点、结束节点、条件节点中的至少一项;
根据所述节点特性,确定所述业务流程对应的功能处理器上下文链路;所述功能处理器上下文链路中包含所述各个功能处理器;
确定所述功能处理器上下文链路为所述业务流程的流程链路。
另一方面,本申请实施例提供一种业务流程的实现装置,包括:
获取模块,用于获取目标业务的业务流程包含的各个功能处理器在所述业务流程中的节点特性;各所述功能处理器对应各自的节点特性;所述节点特性包括流程节点、接入节点、普通节点、结束节点、条件节点中的至少一项;
第一确定模块,用于根据所述节点特性,确定所述业务流程对应的功能处理器上下文链路;所述功能处理器上下文链路中包含所述各个功能处理器;
第二确定模块,用于确定所述功能处理器上下文链路为所述业务流程的流程链路。
再一方面,本申请实施例提供一种业务流程的实现设备,包括处理器和与所述处理器电连接的存储器,所述存储器存储有计算机程序,所述处理器用于从所述存储器调用并执行所述计算机程序以实现上述业务流程的实现方法。
再一方面,本申请实施例提供一种存储介质,用于存储计算机程序,所述计算机程序能够被处理器执行以实现上述业务流程的实现方法。
采用本申请实施例的技术方案,通过获取目标业务的业务流程包含的各个功能处理器在业务流程中的节点特性,根据节点特性确定业务流程对应的功能处理器上下文链路,并确定功能处理器上下文链路为业务流程的流程链路。可见,该技术方案通过将基于业务流程中各功能处理器的节点特性,确定出的功能处理器上下文链路,作为该业务流程的流程链路,由于各功能处理器对应的节点特性是根据各业务流程确定的,因此同一业务流程对应的流程链路是确定的,使得开发人员在实现各业务的业务流程时,仅关心如何实现各功能处理器即可,无需关心各功能处理器之间的衔接,降低了业务开发的复杂性,提升了业务流程的可读性,且节约了开发成本。
附图说明
为了更清楚地说明本申请实施例或现有技术中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本申请中记载的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动性的前提下,还可以根据这些附图获得其他的附图。
图1是根据本申请一实施例的一种业务流程的实现方法的示意性流程图;
图2是根据本申请另一实施例的一种业务流程的实现方法的示意性流程图;
图3是根据本申请一实施例的一种业务流程的实现装置的结构示意图;
图4是根据本申请一实施例的一种业务流程的实现设备的硬件结构示意图。
具体实施方式
本申请实施例提供一种业务流程的实现方法及装置,用以解决现有的业务流程实现复杂、可读性差的问题。
为了使本技术领域的人员更好地理解本申请中的技术方案,下面将结合本申请实施例中的附图,对本申请实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本申请一部分实施例,而不是全部的实施例。基于本申请中的实施例,本领域普通技术人员在没有作出创造性劳动前提下所获得的所有其他实施例,都应当属于本申请保护的范围。
图1是根据本申请一实施例的一种业务流程的实现方法的示意性流程图,如图1所示,该方法包括:
S102,获取目标业务的业务流程包含的各个功能处理器在业务流程中的节点特性。
其中,各功能处理器对应各自的节点特性。节点特性可包括流程节点、接入节点、普通节点、结束节点、条件节点等。流程节点和接入节点为一个维度上的节点特性,普通节点、结束节点和条件节点为另一个维度上的节点特性,每个功能处理器在两个维度上分别包含一项节点特性。
若一功能处理器对应的节点特性为流程节点,则该功能处理器对应的节点特性还可包括普通节点或结束节点或条件节点,若一功能处理器对应的节点特性为接入节点,则该功能处理器对应的节点特性为条件节点,以使通过执行该功能处理器中处理业务的方法,能够确定出下一个功能处理器(节点特性为流程节点的功能处理器),然后执行后续业务流程。也就是说,对于任一功能处理器,其节点特性可为如下A1-A4中的一项:A1、流程节点、普通节点;A2、流程节点、结束节点;A3、流程节点、条件节点;A4、接入节点、条件节点。
其中,功能处理器可采用模版设计模式,如采用流程处理程序ProcessHandler、抽象流程处理程序AbstractProcessHandler等模板,再填充不同的业务处理方法,以实现不同的功能处理器。ProcessHandler模板中可包括:interface Internal<T>、Stringprocess(reqParam)、String getBeanName()等组成部分。其中,interface Internal定义了内部接口,用于收集该ProcessHandler的执行结果和需要更新的表数据等。process为处理业务方法。getBeanName用于获取该ProcessHandler的功能处理器名称beanName。reqParam为全局对象,用于存储该ProcessHandler的执行结果、需要更新的表数据、出入参数等数据,以便在线上排查问题,并快速的定位线上问题。
AbstractProcessHandler模板中可包括String beanName、 Internal<T>internal、final class InternalImpl implements Internal<T>、T process(reqParam)、void doBefore(reqParam)、void doAfter(reqParam,result)、T abstract doProcess(reqParam)、Invoker<T>getInvoker()等组成部分。其中,beanName为功能处理器名称。Internal表示定义接口Internal。InternalImpl用于实现接口Internal,完成对功能处理器运行时的数据收集,以供前端在展示和问题定位分析时使用。process为处理业务组合方法。doBefore为调用功能处理器的前置方法,该方法默认实现。doAfter为调用功能处理器的后置方法,该方法默认实现。doProcess为抽象方法,供子类功能处理器实现,该方法为处理该功能处理器的真正业务处理方法。例如,对于判断在途订单处理器,该方法可包括调用第三方接口,获取数据以判断是否含有在途订单等业务逻辑。Invoker为处理非业务的数据处理执行器,如根据执行结果判断该节点是否需要操作数据库、操作哪些表、执行结果的存储等。
S104,根据节点特性,确定业务流程对应的功能处理器上下文链路。
其中,功能处理器上下文链路中包含上述业务流程中的各个功能处理器。可通过状态机模式形成功能处理器上下文链路。
例如, 执行功能处理器上下文链路的部分过程如下:
在上述执行过程中,通过执行名称为execute的方法,对当前功能处理器的节点特性进行判断,并执行当前功能处理器的处理业务(process)方法,以及确定下一个(next)功能处理器,在确定业务流程未结束时,执行next功能处理器的名称为execute的方法,可见,所有功能处理器中都有名称为execute的方法,而该方法执行时,确定出的next功能处理器是不断改变的,因此可认为状态不断改变,但是执行的一直是execute方法,这属于状态机的思想,因此功能处理器上下文链路可通过状态机模式形成。
S106,确定功能处理器上下文链路为业务流程的流程链路。
在本实施例中,通过获取目标业务的业务流程包含的各个功能处理器在业务流程中的节点特性,根据节点特性确定业务流程对应的功能处理器上下文链路,并确定功能处理器上下文链路为业务流程的流程链路。可见,该技术方案通过将基于业务流程中各功能处理器的节点特性,确定出的功能处理器上下文链路,作为该业务流程的流程链路,由于各功能处理器对应的节点特性是根据各业务流程确定的,因此同一业务流程对应的流程链路是确定的,使得开发人员在实现各业务的业务流程时,仅关心如何实现各功能处理器即可,无需关心各功能处理器之间的衔接,降低了业务开发的复杂性,提升了业务流程的可读性,且节约了开发成本。
业务系统一般由多条业务流程构成,通过本申请实施例的方案,每条业务流程由多个功能处理器组成,且各业务流程对应的各自功能处理器上下文链路,各业务流程通过执行不同的业务处理方法,以实现对不同的业务进行处理。例如,对于一个风控业务系统,其业务流程可包括担保流程guaranteeFlow、个人牌流程personFlow、公司牌流程companyFlow、续租流程releFlow、中小企业流程merchFlow、前置流程preflow、前置三期流程preflowV3等,各业务流程通过执行各自的业务处理方法,以实现对各自的业务进行处理。
在实现各业务流程对应的功能处理器上下文链路时,首先要确定各功能处理器对应的节点特性,以下详细说明如何确定各功能处理器对应的节点特性。
在一个实施例中,可判断业务流程中是否包含异步接收流程;若是,则确定执行异步接收流程的第一功能处理器的节点特性为接入节点,以及,确定各个功能处理器中除第一功能处理器之外的功能处理器的节点特性为流程节点;若否,则确定各个功能处理器的节点特性为流程节点。
其中,异步接收流程用于异步接收外部系统的执行结果。外部系统可将执行结果放入消息队列,业务流程通过监听上述消息队列,获得执行结果,以及确定将该执行结果接入到业务流程中的哪一功能处理器。
在本实施例中,通过判断业务流程中是否包含异步接收流程,以确定各功能处理器的节点特性为接入节点或为流程节点,实现方式简单,且确定出的节点特性是与该业务流程相对应的,提高了确定出的节点特性的准确性,从而提高了实现的各业务流程对应的功能处理器上下文链路的准确性。
在一个实施例中,可判断各个功能处理器的前驱节点和后驱节点分别对应的功能处理器是否与业务流程中的、各个功能处理器的前后顺序一致;若是,则确定各个功能处理器的节点特性为普通节点;若否,则判断各个功能处理器的节点特性是否为结束节点或条件节点。
在本实施例中,通过判断各个功能处理器的前驱节点和后驱节点分别对应的功能处理器是否与业务流程中的、各个功能处理器的前后顺序一致,即可确定出节点特性为普通节点的功能处理器,实现方式简单,提升了确定各功能处理器的节点特性的效率。
在一个实施例中,可判断各个功能处理器是否存在后驱节点;若是,则判断各个功能处理器是否请求外部系统,确定请求外部系统的第二功能处理器的节点特性为结束节点;若否,则确定各个功能处理器的节点特性为结束节点。
其中,若一功能处理器存在后驱节点,但该功能处理器不请求外部系统,则该功能处理器的节点特性可为普通节点或条件节点。
在本实施例中,通过判断各个功能处理器是否存在后驱节点,若存在后驱节点,则进一步判断各个功能处理器是否请求外部系统,以及确定请求外部系统的第二功能处理器的节点特性为结束节点,若不存在后驱节点,则确定各个功能处理器的节点特性为结束节点,实现方式简单,能够快速确定出节点特性为结束节点的功能处理器,提升了确定各功能处理器的节点特性的效率。
在一个实施例中,可判断各个功能处理器的后驱节点是否由各功能处理器的执行结果确定;若是,则确定各个功能处理器的节点特性为条件节点。
其中,各执行结果对应各自的后驱节点。例如,执行结果包括a=0、a>0和a<0三种,当前功能处理器的后驱节点对应的功能处理器包括功能处理器5、功能处理器7、功能处理器8中的一项,假设执行结果为a=0时,对应的后驱节点为功能处理器5,执行结果为a>0时,对应的后驱节点为功能处理器7,执行结果为a<0时,对应的后驱节点为功能处理器8,则可认为上述当前功能处理器对应的节点特性为条件节点。
在本实施例中,通过判断各个功能处理器的后驱节点是否由各功能处理器的执行结果确定,即可确定出节点特性为条件节点的功能处理器,实现方式简单,提升了确定各功能处理器的节点特性的效率。
在一个实施例中,确定业务流程对应的功能处理器上下文链路时,可确定功能处理器上下文链路中的开始节点和结束节点分别对应的功能处理器,以及,确定各个功能处理器的前驱节点和后驱节点分别对应的功能处理器。
其中,可根据上述确定出的各功能处理器对应的节点特性,确定各个功能处理器的前驱节点和后驱节点分别对应的功能处理器。例如,节点特性为普通节点的功能处理器,其前驱节点和后驱节点分别对应的功能处理器与业务流程中的、各个功能处理器的前后顺序一致,节点特性为结束节点的功能处理器,其不存在后驱节点对应的功能处理器,节点特性为条件节点的功能处理器,其后驱节点对应的功能处理器由该功能处理器的执行结果确定。
在本实施例中,通过确定功能处理器上下文链路中的开始节点和结束节点分别对应的功能处理器,以及确定各个功能处理器的前驱节点和后驱节点分别对应的功能处理器,实现了确定出业务流程对应的功能处理器上下文链路的效果。
在一个实施例中,可将功能处理器上下文链路封装为默认处理器链路DefaultHandlerContext对象,以及,将功能处理器上下文链路中的各个功能处理器的运行数据存储至全局对象reqParam。
业务流程中的所有功能处理器,主要分为流程节点和接入节点,其中,根据每个节点的动静特性又将功能处理器分为普通节点、结束节点和条件节点,但是无论是流程节点还是接入节点,都会被封装为DefaultHandlerContext对象。
在本实施例中,通过将功能处理器上下文链路封装为默认处理器链路DefaultHandlerContext对象,达到了封装所有数据的处理过程的目的,因此很大程度上减少了业务系统的开发复杂性,实现了高内聚的目标,并且,通过将功能处理器上下文链路中的各个功能处理器的运行数据存储至全局对象reqParam,使得执行业务流程的过程中,能够直接从内存中获取数据,提高了业务处理效率,且便于快速定位问题,为可视化获取每个进件在业务系统中的运行情况提供了基础。
图2是根据本申请另一实施例的一种业务流程的实现方法的示意性流程图,如图2所示,该方法包括:
S201,获取目标业务的业务流程包含的各个功能处理器在业务流程中的节点特性。
其中,各功能处理器对应各自的节点特性。节点特性可包括流程节点、接入节点、普通节点、结束节点、条件节点中的一项。
在执行S201之前,可判断业务流程中是否包含异步接收流程;若是,则确定执行异步接收流程的第一功能处理器的节点特性为接入节点,以及,确定各个功能处理器中除第一功能处理器之外的功能处理器的节点特性为流程节点;若否,则确定各个功能处理器的节点特性为流程节点。其中,异步接收流程用于异步接收外部系统的执行结果。
在执行S201之前,可判断各个功能处理器的前驱节点和后驱节点分别对应的功能处理器是否与业务流程中的、各个功能处理器的前后顺序一致;若是,则确定各个功能处理器的节点特性为普通节点;若否,则判断各个功能处理器的节点特性是否为结束节点或条件节点。
其中,判断各个功能处理器的节点特性是否为结束节点或条件节点时,可判断各个功能处理器是否存在后驱节点;若是,则判断各个功能处理器是否请求外部系统,确定请求外部系统的第二功能处理器的节点特性为结束节点;若否,则确定各个功能处理器的节点特性为结束节点。
其中,判断各个功能处理器的节点特性是否为结束节点或条件节点时,还可判断各个功能处理器的后驱节点是否由各功能处理器的执行结果确定;若是,则确定各个功能处理器的节点特性为条件节点。其中,各执行结果对应各自的后驱节点。
S202,根据节点特性,确定功能处理器上下文链路中的开始节点和结束节点分别对应的功能处理器。
S203,根据节点特性,确定各个功能处理器的前驱节点和后驱节点分别对应的功能处理器。
需要说明的是,本实施例中不对S202和S203的执行顺序进行限定。例如,除本实施例中列举的先执行S202后执行S203的执行顺序外,还可先执行S203后执行S202,或者,同时执行S202和S203。
S204,确定功能处理器上下文链路为业务流程的流程链路。
上述S201-S204的具体实施过程在上述实施例中已进行详细说明,此处不再赘述。
在本实施例中,通过获取目标业务的业务流程包含的各个功能处理器在业务流程中的节点特性,根据节点特性确定业务流程对应的功能处理器上下文链路,并确定功能处理器上下文链路为业务流程的流程链路。可见,该技术方案通过将基于业务流程中各功能处理器的节点特性,确定出的功能处理器上下文链路,作为该业务流程的流程链路,由于各功能处理器对应的节点特性是根据各业务流程确定的,因此同一业务流程对应的流程链路是确定的,使得开发人员在实现各业务的业务流程时,仅关心如何实现各功能处理器即可,无需关心各功能处理器之间的衔接,降低了业务开发的复杂性,提升了业务流程的可读性,且节约了开发成本。
综上,已经对本主题的特定实施例进行了描述。其它实施例在所附权利要求书的范围内。在一些情况下,在权利要求书中记载的动作可以按照不同的顺序来执行并且仍然可以实现期望的结果。另外,在附图中描绘的过程不一定要求示出的特定顺序或者连续顺序,以实现期望的结果。在某些实施方式中,多任务处理和并行处理可以是有利的。
以上为本申请实施例提供的业务流程的实现方法,基于同样的思路,本申请实施例还提供一种业务流程的实现装置。
图3是根据本申请一实施例的一种业务流程的实现装置的结构示意图,如图3所示,业务流程的实现装置包括:
获取模块310,用于获取目标业务的业务流程包含的各个功能处理器在业务流程中的节点特性;各功能处理器对应各自的节点特性;节点特性包括流程节点、接入节点、普通节点、结束节点、条件节点中的至少一项;
第一确定模块320,用于根据节点特性,确定业务流程对应的功能处理器上下文链路;功能处理器上下文链路中包含各个功能处理器;
第二确定模块330,用于确定功能处理器上下文链路为业务流程的流程链路。
在一个实施例中,第一确定模块320包括:
第一确定单元,用于确定功能处理器上下文链路中的开始节点和结束节点分别对应的功能处理器,以及,确定各个功能处理器的前驱节点和后驱节点分别对应的功能处理器。
在一个实施例中,业务流程的实现装置还包括:
第一判断模块,用于判断业务流程中是否包含异步接收流程;异步接收流程用于异步接收外部系统的执行结果;
第三确定模块,用于若是,则确定执行异步接收流程的第一功能处理器的节点特性为接入节点,以及,确定各个功能处理器中除第一功能处理器之外的功能处理器的节点特性为流程节点;
第四确定模块,用于若否,则确定各个功能处理器的节点特性为流程节点。
在一个实施例中,业务流程的实现装置还包括:
第二判断模块,用于判断各个功能处理器的前驱节点和后驱节点分别对应的功能处理器是否与业务流程中的、各个功能处理器的前后顺序一致;
第五确定模块,用于若是,则确定各个功能处理器的节点特性为普通节点;
第三判断模块,用于若否,则判断各个功能处理器的节点特性是否为结束节点或条件节点。
在一个实施例中,第三判断模块包括:
第一判断单元,用于判断各个功能处理器是否存在后驱节点;
执行单元,用于若是,则判断各个功能处理器是否请求外部系统;确定请求外部系统的第二功能处理器的节点特性为结束节点;
第二确定单元,用于若否,则确定各个功能处理器的节点特性为结束节点。
在一个实施例中,第三判断模块包括:
第二判断单元,用于判断各个功能处理器的后驱节点是否由各功能处理器的执行结果确定;各执行结果对应各自的后驱节点;
第三确定单元,用于若是,则确定各个功能处理器的节点特性为条件节点。
在一个实施例中,业务流程的实现装置还包括:
执行模块,用于将功能处理器上下文链路封装为默认处理器链路DefaultHandlerContext对象;以及,将功能处理器上下文链路中的各个功能处理器的运行数据存储至全局对象reqParam。
在本实施例中,通过获取目标业务的业务流程包含的各个功能处理器在业务流程中的节点特性,根据节点特性确定业务流程对应的功能处理器上下文链路,并确定功能处理器上下文链路为业务流程的流程链路。可见,该装置通过将基于业务流程中各功能处理器的节点特性,确定出的功能处理器上下文链路,作为该业务流程的流程链路,由于各功能处理器对应的节点特性是根据各业务流程确定的,因此同一业务流程对应的流程链路是确定的,使得开发人员在实现各业务的业务流程时,仅关心如何实现各功能处理器即可,无需关心各功能处理器之间的衔接,降低了业务开发的复杂性,提升了业务流程的可读性,且节约了开发成本。
本领域的技术人员应可理解,上述的业务流程的实现装置能够用来实现前文所述的业务流程的实现方法,其中的细节描述应与前文方法部分描述类似,为避免繁琐,此处不另赘述。
基于同样的思路,本申请实施例还提供一种业务流程的实现设备,如图4所示。业务流程的实现设备可因配置或性能不同而产生比较大的差异,可以包括一个或一个以上的处理器401和存储器402,存储器402中可以存储有一个或一个以上存储应用程序或数据。其中,存储器402可以是短暂存储或持久存储。存储在存储器402的应用程序可以包括一个或一个以上模块(图示未示出),每个模块可以包括对业务流程的实现设备中的一系列计算机可执行指令。更进一步地,处理器401可以设置为与存储器402通信,在业务流程的实现设备上执行存储器402中的一系列计算机可执行指令。业务流程的实现设备还可以包括一个或一个以上电源403,一个或一个以上有线或无线网络接口404,一个或一个以上输入输出接口405,一个或一个以上键盘406。
具体在本实施例中,业务流程的实现设备包括有存储器,以及一个或一个以上的程序,其中一个或者一个以上程序存储于存储器中,且一个或者一个以上程序可以包括一个或一个以上模块,且每个模块可以包括对业务流程的实现设备中的一系列计算机可执行指令,且经配置以由一个或者一个以上处理器执行该一个或者一个以上程序包含用于进行以下计算机可执行指令:
获取目标业务的业务流程包含的各个功能处理器在业务流程中的节点特性;各功能处理器对应各自的节点特性;节点特性包括流程节点、接入节点、普通节点、结束节点、条件节点中的至少一项;
根据节点特性,确定业务流程对应的功能处理器上下文链路;功能处理器上下文链路中包含各个功能处理器;
确定功能处理器上下文链路为业务流程的流程链路。
可选地,计算机可执行指令在被执行时,还可以使所述处理器:
确定功能处理器上下文链路中的开始节点和结束节点分别对应的功能处理器,以及,确定各个功能处理器的前驱节点和后驱节点分别对应的功能处理器。
可选地,计算机可执行指令在被执行时,还可以使所述处理器:
判断业务流程中是否包含异步接收流程;异步接收流程用于异步接收外部系统的执行结果;
若是,则确定执行异步接收流程的第一功能处理器的节点特性为接入节点,以及,确定各个功能处理器中除第一功能处理器之外的功能处理器的节点特性为流程节点;
若否,则确定各个功能处理器的节点特性为流程节点。
可选地,计算机可执行指令在被执行时,还可以使所述处理器:
判断各个功能处理器的前驱节点和后驱节点分别对应的功能处理器是否与业务流程中的、各个功能处理器的前后顺序一致;
若是,则确定各个功能处理器的节点特性为普通节点;
若否,则判断各个功能处理器的节点特性是否为结束节点或条件节点。
可选地,计算机可执行指令在被执行时,还可以使所述处理器:
判断各个功能处理器是否存在后驱节点;
若是,则判断各个功能处理器是否请求外部系统;确定请求外部系统的第二功能处理器的节点特性为结束节点;
若否,则确定各个功能处理器的节点特性为结束节点。
可选地,计算机可执行指令在被执行时,还可以使所述处理器:
判断各个功能处理器的后驱节点是否由各功能处理器的执行结果确定;各执行结果对应各自的后驱节点;
若是,则确定各个功能处理器的节点特性为条件节点。
可选地,计算机可执行指令在被执行时,还可以使所述处理器:
将功能处理器上下文链路封装为默认处理器链路DefaultHandlerContext对象;以及,将功能处理器上下文链路中的各个功能处理器的运行数据存储至全局对象reqParam。
在本实施例中,通过获取目标业务的业务流程包含的各个功能处理器在业务流程中的节点特性,根据节点特性确定业务流程对应的功能处理器上下文链路,并确定功能处理器上下文链路为业务流程的流程链路。可见,该设备通过将基于业务流程中各功能处理器的节点特性,确定出的功能处理器上下文链路,作为该业务流程的流程链路,由于各功能处理器对应的节点特性是根据各业务流程确定的,因此同一业务流程对应的流程链路是确定的,使得开发人员在实现各业务的业务流程时,仅关心如何实现各功能处理器即可,无需关心各功能处理器之间的衔接,降低了业务开发的复杂性,提升了业务流程的可读性,且节约了开发成本。
本申请实施例还提出了一种存储介质,该存储介质存储一个或多个计算机程序,该一个或多个计算机程序包括指令,该指令当被包括多个应用程序的业务流程的实现设备执行时,能够使该业务流程的实现设备执行上述业务流程的实现方法实施例的各个过程,且能达到相同的技术效果,为避免重复,这里不再赘述。
上述实施例阐明的系统、装置、模块或单元,具体可以由计算机芯片或实体实现,或者由具有某种功能的产品来实现。一种典型的实现设备为计算机。具体的,计算机例如可以为个人计算机、膝上型计算机、蜂窝电话、相机电话、智能电话、个人数字助理、媒体播放器、导航设备、电子邮件设备、游戏控制台、平板计算机、可穿戴设备或者这些设备中的任何设备的组合。
为了描述的方便,描述以上装置时以功能分为各种单元分别描述。当然,在实施本申请时可以把各单元的功能在同一个或多个软件和/或硬件中实现。
本领域内的技术人员应明白,本申请的实施例可提供为方法、系统、或计算机程序产品。因此,本申请可采用完全硬件实施例、完全软件实施例、或结合软件和硬件方面的实施例的形式。而且,本申请可采用在一个或多个其中包含有计算机可用程序代码的计算机可用存储介质(包括但不限于磁盘存储器、CD-ROM、光学存储器等)上实施的计算机程序产品的形式。
本申请是参照根据本申请实施例的方法、设备(系统)、和计算机程序产品的流程图和/或方框图来描述的。应理解可由计算机程序指令实现流程图和/或方框图中的每一流程和/或方框、以及流程图和/或方框图中的流程和/或方框的结合。可提供这些计算机程序指令到通用计算机、专用计算机、嵌入式处理机或其他可编程数据处理设备的处理器以产生一个机器,使得通过计算机或其他可编程数据处理设备的处理器执行的指令产生用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的装置。
这些计算机程序指令也可存储在能引导计算机或其他可编程数据处理设备以特定方式工作的计算机可读存储器中,使得存储在该计算机可读存储器中的指令产生包括指令装置的制造品,该指令装置实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能。
这些计算机程序指令也可装载到计算机或其他可编程数据处理设备上,使得在计算机或其他可编程设备上执行一系列操作步骤以产生计算机实现的处理,从而在计算机或其他可编程设备上执行的指令提供用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的步骤。
在一个典型的配置中,计算设备包括一个或多个处理器(CPU)、输入/输出接口、网络接口和内存。
内存可能包括计算机可读介质中的非永久性存储器,随机存取存储器(RAM)和/或非易失性内存等形式,如只读存储器(ROM)或闪存(flash RAM)。内存是计算机可读介质的示例。
计算机可读介质包括永久性和非永久性、可移动和非可移动媒体可以由任何方法或技术来实现信息存储。信息可以是计算机可读指令、数据结构、程序的模块或其他数据。计算机的存储介质的例子包括,但不限于相变内存(PRAM)、静态随机存取存储器(SRAM)、动态随机存取存储器(DRAM)、其他类型的随机存取存储器(RAM)、只读存储器(ROM)、电可擦除可编程只读存储器(EEPROM)、快闪记忆体或其他内存技术、只读光盘只读存储器(CD-ROM)、数字多功能光盘(DVD)或其他光学存储、磁盒式磁带,磁带磁磁盘存储或其他磁性存储设备或任何其他非传输介质,可用于存储可以被计算设备访问的信息。按照本文中的界定,计算机可读介质不包括暂存电脑可读媒体(transitory media),如调制的数据信号和载波。
还需要说明的是,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、商品或者设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、商品或者设备所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括所述要素的过程、方法、商品或者设备中还存在另外的相同要素。
本申请可以在由计算机执行的计算机可执行指令的一般上下文中描述,例如程序模块。一般地,程序模块包括执行特定任务或实现特定抽象数据类型的例程、程序、对象、组件、数据结构等等。也可以在分布式计算环境中实践本申请,在这些分布式计算环境中,由通过通信网络而被连接的远程处理设备来执行任务。在分布式计算环境中,程序模块可以位于包括存储设备在内的本地和远程计算机存储介质中。
本说明书中的各个实施例均采用递进的方式描述,各个实施例之间相同相似的部分互相参见即可,每个实施例重点说明的都是与其他实施例的不同之处。尤其,对于系统实施例而言,由于其基本相似于方法实施例,所以描述的比较简单,相关之处参见方法实施例的部分说明即可。
以上所述仅为本申请的实施例而已,并不用于限制本申请。对于本领域技术人员来说,本申请可以有各种更改和变化。凡在本申请的精神和原理之内所作的任何修改、等同替换、改进等,均应包含在本申请的权利要求范围之内。
Claims (6)
1.一种业务流程的实现方法,其特征在于,包括:
获取目标业务的业务流程包含的各个功能处理器在所述业务流程中的节点特性;各所述功能处理器对应各自的节点特性;所述节点特性包括流程节点、接入节点、普通节点、结束节点、条件节点中的至少一项;
根据所述节点特性,确定所述业务流程对应的功能处理器上下文链路;所述功能处理器上下文链路中包含所述各个功能处理器;
确定所述功能处理器上下文链路为所述业务流程的流程链路;
其中,所述获取目标业务的业务流程包含的各个功能处理器在所述业务流程中的节点特性之前,所述方法还包括:
判断所述业务流程中是否包含异步接收流程;所述异步接收流程用于异步接收外部系统的执行结果;外部系统将执行结果放入消息队列,业务流程通过监听上述消息队列,获得执行结果,以及确定将该执行结果接入到业务流程中的哪一功能处理器;
若是,则确定执行所述异步接收流程的第一功能处理器的节点特性为接入节点,以及,确定所述各个功能处理器中除所述第一功能处理器之外的功能处理器的节点特性为流程节点;
若否,则确定所述各个功能处理器的节点特性为流程节点;
所述获取目标业务的业务流程包含的各个功能处理器在所述业务流程中的节点特性之前,所述方法还包括:
判断所述各个功能处理器的前驱节点和后驱节点分别对应的功能处理器是否与所述业务流程中的、所述各个功能处理器的前后顺序一致;
若是,则确定所述各个功能处理器的节点特性为普通节点;
若否,则判断所述各个功能处理器的节点特性是否为结束节点或条件节点;
所述判断所述各个功能处理器的节点特性是否为结束节点或条件节点,包括:
判断所述各个功能处理器是否存在后驱节点;
若是,则判断所述各个功能处理器是否请求外部系统;确定请求外部系统的第二功能处理器的节点特性为结束节点;
若否,则确定所述各个功能处理器的节点特性为结束节点;
所述判断所述各个功能处理器的节点特性是否为结束节点或条件节点,包括:
判断所述各个功能处理器的后驱节点是否由各所述功能处理器的执行结果确定;各所述执行结果对应各自的后驱节点;
若是,则确定所述各个功能处理器的节点特性为条件节点。
2.根据权利要求1所述的方法,其特征在于,所述确定所述业务流程对应的功能处理器上下文链路,包括:
确定所述功能处理器上下文链路中的开始节点和结束节点分别对应的功能处理器,以及,确定所述各个功能处理器的前驱节点和后驱节点分别对应的功能处理器。
3.根据权利要求1所述的方法,其特征在于,所述方法还包括:
将所述功能处理器上下文链路封装为默认处理器链路DefaultHandlerContext对象;以及,将所述功能处理器上下文链路中的所述各个功能处理器的运行数据存储至全局对象reqParam。
4.一种业务流程的实现装置,其特征在于,包括:
获取模块,用于获取目标业务的业务流程包含的各个功能处理器在所述业务流程中的节点特性;各所述功能处理器对应各自的节点特性;所述节点特性包括流程节点、接入节点、普通节点、结束节点、条件节点中的至少一项;
第一确定模块,用于根据所述节点特性,确定所述业务流程对应的功能处理器上下文链路;所述功能处理器上下文链路中包含所述各个功能处理器;
第二确定模块,用于确定所述功能处理器上下文链路为所述业务流程的流程链路;
第一判断模块,用于判断业务流程中是否包含异步接收流程;异步接收流程用于异步接收外部系统的执行结果;外部系统将执行结果放入消息队列,业务流程通过监听上述消息队列,获得执行结果,以及确定将该执行结果接入到业务流程中的哪一功能处理器;
第三确定模块,用于若是,则确定执行异步接收流程的第一功能处理器的节点特性为接入节点,以及,确定各个功能处理器中除第一功能处理器之外的功能处理器的节点特性为流程节点;
第四确定模块,用于若否,则确定各个功能处理器的节点特性为流程节点;
第二判断模块,用于判断各个功能处理器的前驱节点和后驱节点分别对应的功能处理器是否与业务流程中的、各个功能处理器的前后顺序一致;
第五确定模块,用于若是,则确定各个功能处理器的节点特性为普通节点;
第三判断模块,用于若否,则判断各个功能处理器的节点特性是否为结束节点或条件节点;
所述第三判断模块包括:
第一判断单元,用于判断各个功能处理器是否存在后驱节点;
执行单元,用于若是,则判断各个功能处理器是否请求外部系统;确定请求外部系统的第二功能处理器的节点特性为结束节点;
第二确定单元,用于若否,则确定各个功能处理器的节点特性为结束节点;
第二判断单元,用于判断各个功能处理器的后驱节点是否由各功能处理器的执行结果确定;各执行结果对应各自的后驱节点;
第三确定单元,用于若是,则确定各个功能处理器的节点特性为条件节点。
5.一种业务流程的实现设备,其特征在于,包括处理器和与所述处理器电连接的存储器,所述存储器存储有计算机程序,所述处理器用于从所述存储器调用并执行所述计算机程序以实现权利要求1-3任一项所述的业务流程的实现方法。
6.一种存储介质,其特征在于,所述存储介质用于存储计算机程序,所述计算机程序被处理器执行以实现权利要求1-3任一项所述的业务流程的实现方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202011104127.XA CN112181378B (zh) | 2020-10-15 | 2020-10-15 | 业务流程的实现方法及装置 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202011104127.XA CN112181378B (zh) | 2020-10-15 | 2020-10-15 | 业务流程的实现方法及装置 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN112181378A CN112181378A (zh) | 2021-01-05 |
CN112181378B true CN112181378B (zh) | 2023-02-24 |
Family
ID=73951195
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202011104127.XA Active CN112181378B (zh) | 2020-10-15 | 2020-10-15 | 业务流程的实现方法及装置 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN112181378B (zh) |
Families Citing this family (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN113609831A (zh) * | 2021-08-05 | 2021-11-05 | 北京金堤科技有限公司 | 产品交付流程模板的生成方法及装置 |
CN113935592A (zh) * | 2021-09-23 | 2022-01-14 | 唯品会(广州)软件有限公司 | 一种合同管理方法、装置、设备及存储介质 |
CN115878648B (zh) * | 2023-02-22 | 2023-05-05 | 成都成电医星数字健康软件有限公司 | 数据逻辑时序自动调整方法、装置、电子设备及存储介质 |
Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102799962A (zh) * | 2012-06-27 | 2012-11-28 | 南京合荣欣业信息技术有限公司 | 一种配置型业务流程系统及其实现方法 |
CN103577906A (zh) * | 2012-07-20 | 2014-02-12 | 杭州勒卡斯广告策划有限公司 | 工作流生成方法、工作流执行方法以及工作流执行系统 |
CN106897809A (zh) * | 2015-12-17 | 2017-06-27 | 北京奇虎科技有限公司 | 工作流程创建方法、工作流设计器和工作流系统 |
CN109976745A (zh) * | 2017-12-27 | 2019-07-05 | 航天信息股份有限公司 | 一种业务流处理方法及装置 |
Family Cites Families (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7983943B2 (en) * | 2005-05-27 | 2011-07-19 | Xerox Corporation | Method and system for workflow process node synchronization |
US9064240B2 (en) * | 2012-04-27 | 2015-06-23 | Hewlett-Packard Development Company, L.P. | Application based on node types associated with implicit backtracking |
-
2020
- 2020-10-15 CN CN202011104127.XA patent/CN112181378B/zh active Active
Patent Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102799962A (zh) * | 2012-06-27 | 2012-11-28 | 南京合荣欣业信息技术有限公司 | 一种配置型业务流程系统及其实现方法 |
CN103577906A (zh) * | 2012-07-20 | 2014-02-12 | 杭州勒卡斯广告策划有限公司 | 工作流生成方法、工作流执行方法以及工作流执行系统 |
CN106897809A (zh) * | 2015-12-17 | 2017-06-27 | 北京奇虎科技有限公司 | 工作流程创建方法、工作流设计器和工作流系统 |
CN109976745A (zh) * | 2017-12-27 | 2019-07-05 | 航天信息股份有限公司 | 一种业务流处理方法及装置 |
Also Published As
Publication number | Publication date |
---|---|
CN112181378A (zh) | 2021-01-05 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN112181378B (zh) | 业务流程的实现方法及装置 | |
CN110704037B (zh) | 一种规则引擎实现方法及装置 | |
CN111768303A (zh) | 交易处理方法、装置、设备及系统 | |
CN112214334A (zh) | 微服务调用方法、装置、电子设备及计算机可读存储介质 | |
CN110782253B (zh) | 基于区块链的交易处理方法、装置及设备 | |
TW201732587A (zh) | 應用app的資源載入方法、業務功能實現方法及裝置 | |
CN110046052B (zh) | 一种服务调用方法及装置 | |
CN111949297B (zh) | 一种区块链智能合约升级方法、装置及电子设备 | |
US11176161B2 (en) | Data processing method, apparatus, and device | |
CN112860412B (zh) | 业务数据处理方法、装置、电子设备及存储介质 | |
CN110019538B (zh) | 一种数据表切换方法及装置 | |
CN110489219B (zh) | 一种调度功能对象的方法、装置、介质和电子设备 | |
CN109582476B (zh) | 数据处理方法、装置及系统 | |
CN110489392A (zh) | 多租户间的数据访问方法、装置、系统、存储介质及设备 | |
CN110704099A (zh) | 联盟链的构建方法、装置和电子设备 | |
CN107402749B (zh) | 实现图片加载库的方法及装置 | |
CN112988604B (zh) | 对象测试方法、测试系统、电子设备及可读存储介质 | |
CN111158940B (zh) | 物联网领域的不同设备的对接和动态加载的方法和装置 | |
CN110750271B (zh) | 服务聚合、聚合服务的执行方法、装置和电子设备 | |
CN110688430A (zh) | 一种获得数据旁路的方法、装置及电子设备 | |
CN117041980B (zh) | 一种网元管理方法、装置、存储介质及电子设备 | |
EP4346191A1 (en) | Data processing method, and apparatus | |
CN112925527B (zh) | 一种调用方法、装置、存储介质及电子设备 | |
CN111984720A (zh) | 一种数据获取方法、装置、电子设备和接口适配装置 | |
CN114237624A (zh) | 基于Go语言的错误处理方法、装置、设备、介质和产品 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
GR01 | Patent grant | ||
GR01 | Patent grant |