Flowable 中 ReceiveTask 怎么玩?

开发 前端
ReceiveTask 往往适用于一些不明确的阻塞,例如:一个复杂的计算需要等待很多条件,这些条件是需要人为来判断是否可以执行,而不是直接执行,这个时候,工作人员如果判断可以继续了,那么就 Trigger 一下使流程继续向下执行。

在之前的案例中,松哥和大家举例最多的 Task 主要是 UserTask 和 ServiceTask,ReceiveTask 虽然也和大家提过但是没有仔细讲过,今天我们就来捋一捋 ReceiveTask 在 Flowable 中到底怎么玩。

1. 使用场景

接受任务(Receive Task),接触过 Flowable 的小伙伴应该是见过或者听说过,它的图标如下图:

图片

ReceiveTask 可以算是 Flowable 中最简单的一种任务,当该任务到达的时候,它不做任何逻辑,而是被动地等待用户 Trigger。

ReceiveTask 往往适用于一些不明确的阻塞,例如:一个复杂的计算需要等待很多条件,这些条件是需要人为来判断是否可以执行,而不是直接执行,这个时候,工作人员如果判断可以继续了,那么就 Trigger 一下使流程继续向下执行。

基于以上介绍,ReceiveTask 还有一个中文名字叫做等待任务,也就是说,流程走到 ReceiveTask 这个节点的时候,就卡住了,需要用户手动点一下,流程才会继续向下走。

2. 实践

2.1 绘制流程图

我们绘制一个简单的流程图来看下 ReceiveTask 到底是啥样子,流程图如下:

图片

ReceiveTask 图标上有一个信封。

小伙伴们绘制的时候,首先选择用户任务:

图片

然后点击设置按钮,将用户任务切换为 ReceiveTask 即可:

图片

绘制完成后,我们下载这个流程图对应的 XML 文件。

来看看,带 ReceiveTask 的流程图是下面这样的:

<process id="receiveTask_demo" name="接收任务测试流程" isExecutable="true">
<documentation>接收任务测试流程</documentation>
<startEvent id="startEvent" flowable:formFieldValidation="true"></startEvent>
<sequenceFlow id="sid-9E7B327E-EFC8-4D29-8C6F-157D5E1B7A4E" sourceRef="startEvent" targetRef="todaySales"></sequenceFlow>
<receiveTask id="todaySales" name="统计今日销售额"></receiveTask>
<receiveTask id="sendMsg" name="发送今日销售业绩给老板"></receiveTask>
<endEvent id="endEvent"></endEvent>
<sequenceFlow id="s2" sourceRef="todaySales" targetRef="sendMsg"></sequenceFlow>
<sequenceFlow id="s3" sourceRef="sendMsg" targetRef="endEvent"></sequenceFlow>
</process>

2.2 部署

这个松哥在之前的文章中已经反复介绍过多次了,这里就不再赘述了,大家参考我们之前的文章部署并启动上面这个流程。

2.3 分析

当流程启动之后,按照我们前面文章的分析,我们先去数据库中 ACT_RU_TASK​ 表进行查看,发现该表空空如也。也就是 ReceiveTask 并不会被记录在 ACT_RU_TASK​ 表中,他们只是单纯的被记录在 ACT_RU_EXECUTION 表中,因为在该表中,我们可以查看 ReceiveTask 的记录。

对于 ReceiveTask 的触发方式也很简单,如下:

@Test
void test10() {
List<Execution> list = runtimeService.createExecutionQuery().activityId("todaySales").list();
for (Execution execution : list) {
runtimeService.trigger(execution.getId());
}
}

由于 ReceiveTask 的触发需要传入的参数是执行实例 ID 而不是流程实例 ID,所以我们要查询出来当前待触发的执行实例 ID。具体的查询方式就是根据 ReceiveTask 的节点名称去查询。

查询到执行实例 ID 之后,调用 trigger 方法完成触发,使得流程继续向下走。

好啦,现在流程进入到发送今日销售业绩给老板这个环节了,老办法继续查询并执行:

@Test
void test10() {
List<Execution> list = runtimeService.createExecutionQuery().activityId("sendMsg").list();
for (Execution execution : list) {
runtimeService.trigger(execution.getId());
}
}

这个执行完层后,这个流程就结束了。现在我们去查看 ACT_RU_ACTINST​ 表已经空了,查看 ACT_RU_EXECUTION 表也空了。

责任编辑:武晓燕 来源: 江南一点雨
相关推荐

2022-11-14 10:44:59

HTMLFlowable外置

2022-02-18 11:05:25

Jpa配置Address

2018-06-26 15:58:39

进程内缓存缓存数据

2022-04-13 10:05:48

网关Flowable事件订阅

2017-09-19 14:13:53

Snapshot数据库HBase

2012-06-26 11:27:40

Windows Pho

2021-10-27 15:04:27

OpenTTD模型火车开源

2018-02-28 10:05:00

AI电商业务人脸识别

2021-01-20 05:35:08

PythonMock微服务

2022-05-30 16:19:26

C#多态底层虚方法

2020-11-16 07:15:41

Linux权限管理

2017-03-28 11:39:58

深信服超融合平台

2020-02-12 11:34:56

架构平滑上云机房迁移

2023-02-13 18:32:59

AI绘画

2011-07-10 14:01:45

复合一体机技巧

2022-06-21 14:18:06

RBACTienChin项目

2015-12-16 18:07:09

乐视体育

2017-03-27 15:07:15

云计算2BApp Store

2024-03-15 08:06:58

MySQLJOIN命令

2020-05-28 15:41:48

微软C+语言
点赞
收藏

51CTO技术栈公众号