level 9
公司内部的OA系统最近要升级改造,由于人手不够就把我借调过去了,但说真的我还没做过这方面的功能,第一次接触工作流的开发,还是有点好奇是个怎样的流程。
2020年12月05日 02点12分
2
level 9
项目主要用 Springboot + Flowable 重构原有的工作流程,Flowable 是个用 Java语言写的轻量级工作流引擎,上手比较简单开发效率也挺高的,一起学习下这个框架。
2020年12月05日 02点12分
3
level 9
<!--flowable工作流依赖-->
<dependency>
<groupId>org.flowable</groupId>
<artifactId>flowable-spring-boot-starter</artifactId>
<version>6.3.0</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>1.3.2</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<scope>runtime</scope>
</dependency>
2020年12月05日 02点12分
4
level 9
流程设计
工作流开发的核心是任务流程的设计,Flowable 官方建议采用业界标准BPMN2.0的 XML来描述需要定义的工作流。
我们需要在 resource 目录下创建 processes路径,存放相关的 XML流程配置文件。Flowable 框架会默认加载此目录下的工作流文件并解析 XML,并将解析后的流程配置信息持久化到数据库。
2020年12月05日 02点12分
5
level 9
Flowable 是依赖于数据库的,但它并不需要我们手动的创建表,而是在程序第一次启动时,自动的向MySQL 中创建它所需要的一系列表。
2020年12月05日 02点12分
6
level 9
看到项目启动成功一共生成了60个表,数量还是比较多的,建议使用专门的数据库存在这些工作流表。
2020年12月05日 02点12分
8
level 9
举个栗子:假如一个请假流程,需要经理审核通过,请假才能生效,如果他驳回流程结束。
2020年12月05日 02点12分
9
level 9
接下来我们用 XML 翻译下上边的请假流程图,整体非常简单只要够细心就行了,一起看看每个标签都是什么含义。
2020年12月05日 02点12分
10
level 9
其实就是把流程图的各种线条逻辑,用不同的XML标签描绘出来了。
<process> :表示一个完整的工作流
<documentation> :对工作流的描述
<startEvent> :工作流中起点位置(开始)
<endEvent > :工作流中结束位置(结束)
<userTask> :代表一个任务审核节点(组长、经理等角色)
2020年12月05日 02点12分
11
level 9
<exclusiveGateway> :逻辑判断节点,相当于流程图中的菱形框
<sequenceFlow> :链接各个节点的线条,sourceRef 属性表示线的起始节点,targetRef 属性表示线指向的节点。
上边这一大坨XML是不是看着超级麻烦,要是有自动生成工具就好了,我发现IDEA自带设计工具,但实在是太难用了。
2020年12月05日 02点12分
12
level 9
流程审批
流程设计完后剩下的就是对工作流的审批和生成流程图。
首先启动一个请假的流程,以员工ID staffId 作为唯一标识,XML文件中会接收变量 leaveTask,Flowable内部会进行数据库持久化,并返回一个流程Id processId ,用它可以查询工作流的整体情况,任务Id task为员工具体的请假任务。
注意:一个请假流程 processId中可以包含多个请假任务 taskId。
2020年12月05日 02点12分
13
level 9
用启动流程时返回的 processId 看一下一下当前的流程图
2020年12月05日 02点12分
15
level 9
接下来将请假申请进行驳回 ,传入相应的 taskId 后执行驳回,再看看整个工作流的效果。
2020年12月05日 02点12分
16
level 9
开发工作流一般多用在OA系统等传统项目中,我也是第一次尝试做此类功能,收获还是蛮多的,技术栈又压进了一个知识点。今天分享的是个超级简单的demo,因为也是刚开始接触,等我用的贼溜的时候,再给小伙伴们做更成熟更深入的分享。
2020年12月05日 02点12分
17