如何设计一个灵活的审批流程

简介: 如何设计一个灵活的审批流程

背景

    如何选择一个合适的审批流程,决定了业务逻辑的复杂度。因此选择合适的审批实现方式很重要。在售后,流程式的代码也较多,因此需要选择一个合适的方式。


一、需求

比如当前的流程存在多个步骤,每个步骤都需要人审批,此时的设计方案如何设计比较好?


二、方案

方案一:

这种模式适用于固定流程和可变长短流程

是基于当前的步骤,建立审批流,比如Activiti、Flowable或者阿里开源的审批流框架等,这个时候,此时每个判断条件放在审批流的排他网关上,也即左右变量上,解决流程上的繁琐判断。但是这样有一个问题:需要有一个专门管理的审批流来管理流程。由于审批流和角色挂钩,因此不免需要和认证中心做交互。如果当前的审批流程比较长,会出现一个问题,审批中心出现异常,我们的审批信息也需要进行回滚。由于审批中心和业务系统不在同一个服务,属于不同的领域,因此需要使用分布式事务来保证事务。这个成本上,会有点大。通常审批流较短的话,使用审批流框架比较方便。


方案二:

这种模式适应于固定流程和长度可变流程。

采用数据库预置全流程的方式,此时全流程事先插入到数据库,此时每个流程都会带上角色信息、金额、类型信息。也即比如根据金额和类型,查询对应的流程的步骤。然后将其待处理流程插入到数据库中。当轮到那个角色审批的时候,就进行对应的审批行为,进行审批。此时不需要审批流框架的加持也能完成这个过程。


改进方式:

但是这种方案还是不够灵活。由此我想到还有一种方式可以实现这种操作。也即在每次插入数据库前,将每个待审批的流程数据结构设计成json的数据结构,json里面带分支状态,结合状态来判断,这样每次执行完成,再增加一个总的状态,这样每次执行完成,就代表这个过程成功了,否则回退一个状态即可。


由于json数据结构,方便扩展,因此每次操作的过程还可以带上sort这个字段,这样方便排序的同时,还方便状态的标注。


出现异常与方案一相比,方便回滚。不会存在分布式事务的问题。

但是方案二有一个问题,就是出现多分支的时候,需要给定一个排序的字段。借助一些属性信息来区分。但是方案一对于多分支的情况,依然适用。


方案三:

通常基于审批流程,如果是固定的,可以基于责任链模式,来设计审批流程。责任链模式最典型的代表就是Sentinel。基于SPI构建出来的典型固定流程的设计模式。其本质类似于链表的数据结构。


三、可视化

当然对于这种模式,最好是有一个界面能够进行维护,这样方便可视化。可视化界面减少运维成本。同时能够带上开关,避免因为流程带来的问题。


四、总结

三种方案,各有各的好,但是相对成本而已,方案二的成本要比方案一的成本要低一些 同时方便维护。但是如果是同一级多分支的情况下,使用专业的工作流更为合理。如果当前的审批比较固定,则选择方案三更为合理,成本小,易于维护。

目录
相关文章
|
6月前
|
UED
点晴OA办公系统如何实现业务表单的自定义设计
在点晴OA办公系统中,业务表单的自定义设计是一项重要的功能,它能够满足企业不同的业务需求,提高工作效率和协作能力。 随着企业的发展,不同的业务部门需要处理各种类型的表单,如人事表单、财务表单、项目表单等。如果这些表单无法根据实际需求进行自定义设计,就会导致工作效率低下、信息不准确、协作困难等问题。因此,实现业务表单的自定义设计是提高企业办公效率和协作能力的重要手段。
94 0
|
数据可视化 IDE 安全
云巧-让开发更简单,更高效,更方便
近年来,快速迭代的新需求将引导企业改变其开发方式,进而转向使用支持快速、安全和高效的技术架构,组装式应用便成为了企业重要的战略技术趋势。组装式应用引入模块化的理念,使得各企业可以更敏捷、更有效地复用能力模块,提高商业的韧性和效率。云巧平台应运而生,能极大的改善开发环境,节省开发工作量,让开发更简单,更高效,更方便。
1894 0
|
1月前
|
搜索推荐 数据可视化 安全
化繁为简,使用 ADManager Plus 简化账户生命周期管理
推荐大家尝试一下 ADManager Plus 的编排功能,我们管理工作中遇到的繁琐内容可以直接通过简单设置添加实现,简化了账户生命周期管理。ADManager Plus 可以提供一次免费个性化演示的机会,专业的解决方案专家将向您展示如何与公司内部环境结合使用,还可以一对一的对您的疑问进行解答。
|
3月前
|
运维 数据可视化 持续交付
业务需求协作管理
业务需求协作管理
31 1
|
3月前
|
测试技术 持续交付
探索式测试:一种高效且灵活的软件质量保证策略
在快速迭代和持续交付的软件开发环境中,传统的测试方法往往难以应对日益增长的测试需求。探索式测试作为一种灵活而高效的测试实践,强调测试人员的个人技能和经验,鼓励在测试过程中不断探索和学习。本文将介绍探索式测试的核心概念、实施步骤以及如何将其与传统测试方法相结合,以提升软件质量和测试效率。
|
4月前
|
设计模式 算法 运维
开发与运维开发问题之什么是模版模式,模版模式在业务接口设计中如何应用
开发与运维开发问题之什么是模版模式,模版模式在业务接口设计中如何应用
|
6月前
|
自然语言处理 供应链 监控
财务记账软件推荐:解锁进销存一体化管理,灵活自定义功能
Zoho Books是一款集成进销存管理的财务软件,提供自定义字段、报表和审批流程,支持多语言多货币,适合国际化企业。它实现了资金流、物流和信息流的无缝对接,具有采购、销售和库存管理功能,如供应商管理、采购订单、库存追踪和销售订单处理。此外,软件支持移动端应用和与其他应用集成,助力企业高效运营和精准决策。
72 2
|
6月前
|
前端开发
基于jeecgboot流程管理平台的自定义业务表单集成方法
基于jeecgboot流程管理平台的自定义业务表单集成方法
157 0
|
6月前
|
安全
什么是短剧系统开发/需求设计/逻辑方案/项目指南
The short drama system development plan refers to the development of a system for organizing and managing the process of short drama production, release, and playback.
|
安全 搜索推荐 区块链
NewFi智能合约项目系统开发|NewFi模式系统开发(详情规则)
区块链技术可以帮助Web3.0实现去中心化的功能