目录
1. Flowable
简介
Flowable
是一个用 Java
编写的轻量级业务流程引擎。Flowable
流程引擎允许您部署 BPMN 2.0
流程定义(用于定义流程的行业 XML
标准)、创建这些流程定义的流程实例、运行查询、访问活动或历史流程实例和相关数据
Flowable
在将其添加到应用程序、服务、体系结构时非常灵活。您可以将引擎嵌入到您的应用程序或服务中,方法是包含 Flowable
库,该库作为 JAR
提供。因为它是一个 JAR
,所以可以很容易地将它添加到任何 Java
环境中:javase;servlet
容器,如 Tomcat
或 Jetty、Spring;javaee
服务器,如 JBoss
或 WebSphere
等。或者,您可以使用可流动的 restapi
通过 HTTP
进行通信。还有一些可流动的应用程序(Flowable Modeler、Flowable Admin、Flowable IDM 和 Flowable Task
),它们提供了用于处理流程和任务的现成示例 UI
Flowable
的 GitHub
官网:https://github.com/flowable/flowable-engine
Flowable
中文用户书册:https://tkjohn.github.io/flowable-userguide/#_advanced
现在市面上主流的流程引擎就一共有三个:
Activiti
Flowable
Camunda
这三个各有特点:
Activiti
目前是侧重云,他目前的设计会向Spring Cloud
、Docker
这些去靠拢Flowable
核心思想还是在做一个功能丰富的流程引擎工具,除了最最基础的工作流,他还提供了很多其他的扩展点,我们可以基于Flowable
实现出许多我们想要的功能(当然这也是小伙伴们觉得Flowable
使用复杂的原因之一)Camunda
相对于前两个而言比较轻量级,Camunda
有一个比较有特色的功能就是他提供了一个小巧的编辑器,基于bpmn.io
来实现的。如果你的项目需求是做一个轻巧的、灵活的、定制性强的编辑器,工作流是嵌入式的,那么可以选择Camunda
工作流程图这块其实有一个统一的标准,那就是 BPMN
。BPMN
全称是 Business Process Model and Notation,中文译作业务流程模型和标记法,这个中文太绕口了,还是简称 BPMN
吧
这是一套图形化表示法,用图形来表示业务流程模型。BPMN
最初由业务流程管理倡议组织(BPMI, Business Process Management Initiative
)开发,BPMI
于 2005
年与对象管理组织(OMG, Object Management Group
)合并,并于 2011
年 1
月 OMG
发布 2.0
版本,同时改为现在的名称
一句话,就是流程图这块有一个特别古老的规范,那就是 BPMN
,而我们前面所说的无论是 Activiti、Flowable
还是 Camunda
,都是支持这个规范的,所以呢,无论你使用哪一个流程引擎,都可以使用同一套流程图
2. 绘制工作流程图
2.1. Flowable UI
的安装部署
首先下载文件 Flowable
相关的资源,进入 https://github.com/flowable/flowable-engine/releases,选择版本下载,下载下来是一个 ZIP
压缩包,解压压缩会看到如下目录结构
2.2. 启动服务
进入 wars
目录,会看到 flowable-rest.war
和 flowable-ui.war
两个 war
文件,然后 cmd
执行如下命令
java -jar flowable-ui.war
如果一闪而过则检查 jdk
的环境变量配置。启动成功后,在浏览器中访问 http://localhost:8080/flowable-ui/#/
,默认的账号密码是:admin/test
2.3. 用户管理
我们先在 身份管理应用程序
中创建用户并授权
创建用户
填写详细信息
授权管理
2.4. 工作流程效果图
最后完成的工作流程图如下
2.5. 绘制工作流程图
点击创建流程,填写相关的信息
进入流程图绘制界面
2.5.1. 添加开始事件
2.5.2. 添加用户活动(用户审批)
2.5.3. 添加网关
2.5.4. 添加结束事件
2.5.5. 设置【主管审批】的相关属性
- 主键
ID
:可以结合业务需求,业务可以根据不同步骤执行不同的业务操作 - 分配用户:这里为了方便,直接选择了固定值,这里的候选组是具体的业务系统的角色
ID
从而实现不同角色审批不同流程的效果
2.5.6. 设置【网关】的流条件
2.5.6.1. 同意的条件
- 连线条件的输入框是支持
EL
表达式,因此可以使用${}
- 【同意的条件】:这里填写了
${executeType=='YES'}
的意思是主管审批的时候传递一个executeType
变量,并且executeType
变量的值为YES
的时候,则走到下一步(经理审批)
2.5.6.2. 拒绝的条件
- 这里填写了
${executeType=='YES'}
的意思是主管审批的时候传递一个executeType
变量,并且executeType
变量的值为NO
的时候,则结束流程
2.6. 下载工作流程图
<?xml version="1.0" encoding="UTF-8"?>
<definitions xmlns="http://www.omg.org/spec/BPMN/20100524/MODEL" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:flowable="http://flowable.org/bpmn"
xmlns:bpmndi="http://www.omg.org/spec/BPMN/20100524/DI"
xmlns:omgdc="http://www.omg.org/spec/DD/20100524/DC" xmlns:omgdi="http://www.omg.org/spec/DD/20100524/DI"
typeLanguage="http://www.w3.org/2001/XMLSchema" expressionLanguage="http://www.w3.org/1999/XPath"
targetNamespace="http://www.flowable.org/processdef" exporter="Flowable Open Source Modeler"
exporterVersion="6.7.2">
<process id="MyLeave" name="MyLeave" isExecutable="true">
<documentation>员工请假流程</documentation>
<startEvent id="sid-159DD77D-9878-4288-AC29-B898E08DC216" flowable:formFieldValidation="true"></startEvent>
<userTask id="zgID" name="主管审批" flowable:assignee="张主管" flowable:formFieldValidation="true">
<extensionElements>
<modeler:initiator-can-complete xmlns:modeler="http://flowable.org/modeler">
<![CDATA[false]]></modeler:initiator-can-complete>
</extensionElements>
</userTask>
<sequenceFlow id="sid-1E8F84D7-6C11-4D88-84C9-B818474F880E" sourceRef="sid-159DD77D-9878-4288-AC29-B898E08DC216"
targetRef="zgID"></sequenceFlow>