详解SpringCloud集成Camunda7.19实现工作流审批(二)
本章将分享的是camunda流程设计器--Camunda Modeler的基本使用(对应camunda版本是7.19),包括bpmn流程图画法,各种控件使用以及一些日常业务场景的流程图的实现
参考资料:
Camunda BPMN 基础组件-CSDN博客
Camunda: ExecutionListener执行监听器和TaskListener任务监听器-CSDN博客
snail-camunda: Camunda二次封装以及相关功能使用介绍。 中国式工作流解决方案。
文章目录
- 一、常用控件
- 1.事件(Event)
- 2.任务(Task)
- 3.网关(Gateway)
- 二、流程设计器使用
- 1.新建模型
- 2.命名流程图
- 3.拖拽控件画图
- 4.监听器配置
- 5.网关配置
- 6.子流程
- 1.内部子流程
- 2.外部子流程(活动调用)
- 三、实战演示
一、常用控件
1.事件(Event)
事件是BPMN2.0中一个非常重要的概念,是流程运行过程中发生的事情,而这些事情的发生会影响到流程的流转。对每个事件而言,一般会包含两个要素,分别是触发这个事件的原因,以及由此导致的结果。
以下是一些常用的事件类型
-
(空白)开始事件
如下图所示,开始事件是流程图里必须要有的元素,同时一个流程图只能有且仅有一个空白开始事件

-
结束事件
标志流程的一个实例或一个分支走向结束,在一个流程图里可以存在多个结束事件节点;结束事件不会影响其他并行路径的执行,只是结束它所在的特定路径。

-
终止事件
终止事件是 BPMN 2.0 引入的一种特殊类型的结束事件。它会导致整个流程(包括所有并行路径)立即终止。

-
流程立即终止:终止事件会导致整个流程立即终止,无论是否有其他并行路径正在执行。
-
单一实例:一个流程中只能有一个终止事件。如果有多个终止事件,流程引擎将不知道该执行哪个。
-
影响所有路径:终止事件会影响整个流程的所有并行路径,不仅仅是一个分支。
-
计时器事件
计时器事件可以用作启动事件、中间事件或边界事件。边界事件可以中断,也可以不中断。
下图里的是边界中断事件,表示的是10秒后还在该节点则判定超时,会中断流程走向下面的路线

-
错误事件
错误事件分为 错误启动事件 和 错误边界事件
-
错误启动事件
如下图,错误结束节点后会触发下面的事件子流程,由事件子流程中的错误启动事件进行处理
只能用于触发事件子流程,而不能用于启动流程实例。错误启动事件始终处于中断状态
-

注意选择相同的错误定义,这样才能被捕获

-
错误边界事件
边界事件可以捕获中间错误,中断流程并重新控制流程走向,如下图所示,由于系统任务执行主动抛出了BpmnError异常,然后就被错误边界事件捕获处理了。


2.任务(Task)
任务表示流程中的工作单位,需要人工或系统执行特定的动作。
-
系统任务
即不需要人工处理,而是由系统自动处理的任务。通常调用外部服务或脚本。可以配置 Java 类、表达式或外部任务来实现任务逻辑。
由于项目中我用到系统任务的不多,这里只展示配置java类的方式。
如下图,type选择java class,然后配置java类的全路径

java类如下,实现JavaDelegate接口
execution对象里可以获取到流程实例的各种信息,也可以对流程实例进行操作,如下面的设置流程变量等
public class TestCalculateErrorDelegate implements JavaDelegate {@Overridepublic void execute(DelegateExecution execution) throws Exception {Integer numerator = 0;Integer denominator = 0;try {int result = numerator / denominator;execution.setVariable("result", result);} catch (Exception e) {execution.setVariable("calculateErrorCode", "4098");execution.setVariable("calculateErrorMsg", "除数不能为0");throw new BpmnError("4098", "除数不能为0");}}
}
-
用户任务
用户任务即需要人工参与者完成的任务。当流程执行到用户任务节点时,将会给这个节点分配的用户创建待办任务。
如下图所示,分配该用户任务节点给了admin

这里的assignee在真实业务场景中,一般会设置成流程变量,进行动态的赋值,如下图
${assignee}代表这里取值是取流程实例中的assignee变量,这样就可以结合具体业务动态地给这个地方赋值了

多实例用户任务
一个用户任务节点也可以是多个参与者,同时又分为 并行 和 串行 2种类型
如下图,通过点击修改属性按钮,可以看到右上角有两个类型选项,第一个是并行,第二个串行

-
并行
并行又分为或签(一个人通过即通过)、比例签(通过人数达到总人数XX比例即通过)还有会签(需要全部人都通过才通过)
如下图是或签,配置与单实例任务有所不同
第一行是固定写法,同理的还有:
//比例签,需要满足0.3比例通过 ${nrOfCompletedInstances/nrOfInstances > 0.3 } //会签,需要全部通过 ${nrOfCompletedInstances == nrOfInstances}

-
串行
串行即多个人依次审批,待办任务也是只有当到自己审批的时候才会创建。配置逻辑和并行的基本同理。

3.网关(Gateway)
在流程中,需要根据条件分叉或合并路线的时候,就需要用到网关。
-
排他网关
会依次判断所有的路径,然后走符合条件的第一条路径
如下图所示

-
并行网关
允许同时走多个分叉路径,都走完后合并后再走后面的节点
并行网关是没有条件限制的
如下图所示

-
包含网关
与并行网关类似,区别在于可以设置条件限制,满足条件的路径就会走
如下图所示的请假流程,当请假天数大于3天,既会走经理审批,同时也会走老板审批,两个都审批好后再汇集走下个节点

二、流程设计器使用
这里我们以camunda7.19为例,讲解流程设计器的基本使用
1.新建模型
如下图所示,新建的时候选择camunda 7版本,并且左下角再选择小版本号为7.19


2.命名流程图
创建新文件后,默认会有一个开始节点,然后我们需要先点击下空白处,然后在右边的窗口里输入流程的名字和流程的ID(流程定义key)
Name可以在后面作为流程名称(流程类型)来使用,而流程定义key(表里是PROC_DEF_KEY_ ) 则是该流程图的唯一标识
区别于流程定义id,即表里的PROC_INST_ID_, 每次修改了图重新部署都会变,对应的是这个图的某个版本;流程定义key则图修改重新部署后不会变

3.拖拽控件画图
从左边的控件栏选择后拖拽到画板即可,这里常用的控件上面已经介绍过。

4.监听器配置
在流程中,我们经常要在节点前或节点后去做一些操作,这时候我们就可以使用监听器来实现。
执行监听器 ExecutionListener触发事件有:start、end、take;
其中节点有start、end两种事件,而连线则有take事件。
任务监听器TaskListener触发事件有:create, assignment, update, complete, delete or timeout。
-
执行监听器 ExecutionListener
如下图,就是在开始节点配置了执行监听器,start时触发
监听器类型是java类,即会执行下面的java方法

这里的java类实现ExecutionListener接口,如下所示
public class ProcessStartExecutionListener implements ExecutionListener {@Overridepublic void notify(DelegateExecution execution) throws Exception {//初始化状态为审批中execution.setVariable("approveState", 0);log.info("初始化状态为审批中---------------approveState=0");}}
监听器除了用java类,常用的还有脚本片段,如下图所示

注意:
脚本使用的是groovy语言,需要先在springboot项目中引入groovy依赖,否则会报错找不到引擎
<dependency><groupId>org.codehaus.groovy</groupId><artifactId>groovy-jsr223</artifactId><version>3.0.15</version><scope>runtime</scope>
</dependency>
-
任务监听器 TaskListener
如下图,任务节点create的时候,会执行监听器逻辑,同样可以配置java类或脚本片段

java类参考下面,实现TaskListener接口
public class ProcessReturnTaskListener implements TaskListener {@Overridepublic void notify(DelegateTask delegateTask) {// 设置变量variable1值为1delegateTask.setVariable("variable1", 1);log.info("流程退回变量初始化值为1成功, taskId:{}, variableName:{}", delegateTask.getId(), variableName);}}
}
-
监听器执行顺序
下图为例

执行顺序:1. 开始节点:start -》 end2. 连线:take3. 任务节点ExecutionListener: start4. 任务节点TaskListener:create -》 assignment -》 complete5. 任务节点ExecutionListener: end6. 连线:take7. 结束节点:start - 》 end
5.网关配置
当我们的业务需要根据条件来判断不同走向的时候,就需要配置网关
如下图,实现的是流程变量t0等于1则走向admin审批,t0等于0时则直接走向结束

需要在网关后的两条连线配置条件,如下

也可以使用groovy脚本,如下

6.子流程
有的时候某个节点需要走一套流程来实现业务,例如某个多实例并行节点,在节点中有需要有自己的审批、退回等操作,这个时候就可以用到子流程来实现。子流程又分为 内部子流程和外部子流程(活动调用)
1.内部子流程
如下图所示
要注意的是,图里子流程的t1变量是针对整个(父)流程的,也就是如果其中一个子流程赋值了t1变量,其他子流程里的t1变量也会受影响,在真实业务中需要注意这点。

2.外部子流程(活动调用)
如下图所示
外部子流程即触发另一个流程图的流程,在数据表里也是会新增另一个流程定义key的数据(内部子流程不会,还是只是父流程定义key的数据)
下图右边栏里的called element配置的就是子流程图的定义key
父流程

子流程

采用外部子流程,则子流程里的变量是针对子流程实例的,所以不同子流程的变量不会互相影响
三、实战演示
关于流程图的示例,可以学习:
snail-camunda: Camunda二次封装以及相关功能使用介绍。 中国式工作流解决方案。

相关文章:
详解SpringCloud集成Camunda7.19实现工作流审批(二)
本章将分享的是camunda流程设计器--Camunda Modeler的基本使用(对应camunda版本是7.19),包括bpmn流程图画法,各种控件使用以及一些日常业务场景的流程图的实现 参考资料: Camunda BPMN 基础组件-CSDN博客 Camunda: Exe…...
Matlab学习笔记
Magic Traits 文件读取 fid fopen(fn,rt);out fscanf(fid,spec,inf);fclose(fid);2. 读取数据 fid fopen(fn,rt); out textscan(fid,spec);运算篇 fprintf(" xxx %d",a),当a为数组时,会输出数组数目行,每行是一个元素相关文…...
Hexo博客在多个设备同步
title: ‘Hexo博客在多个设备同步’ date: 2024-11-28 19:08:08 categories: Hexo教程 cover: /img/cover4.jpg description: ‘实现Hexo博客在不同的设备上都可以使用和上传’ 博客链接1 :Hexo搭建博客的多终端同步问题 博客链接2:Hexo博客多台电脑设备同步管理 …...
淘宝Vision Pro:革新购物体验的沉浸式未来
引言 简要介绍淘宝Vision Pro版的背景,包括它在美区AppStore的发布及WWDC上的展示。阐述本文的目的:为读者提供一个全面的功能概览与设计背后的思考。设计原则 列出并简要解释5条设计原则(熟悉、直观、真实、实用、易用)。说明这些原则如何指导整个产品设计过程。核心功能详…...
公链开发中的技术实现路径:构建高效、安全的去中心化网络
区块链技术作为数字经济的重要组成部分,公链(Public Chain)是其核心架构之一。公链作为去中心化的数字账本,不仅承载着去中心化应用(DApp)的运行,还确保了交易的透明、安全性。随着区块链技术的…...
mac上的建议xftp 工具
mac上的建议xftp 工具 最近使用mac比较频繁了,但是第一次重度使用mac里面有很多的工具都是新的,有的window版本的工具无法使用。 xftp 的平替 Cyberduck 从它的官网上下载是免费的,但是如果使用 Apple store 要花费198呢。这不就剩下一大笔…...
Android 使用Charles抓包显示Unknown
最近开发的一个功能需要抓包验证一下网络请求的结果。 但是在配置完Charles的证书代理等设置后,抓包时显示Unknown。 在网上查了半天资料和文章,最终解决了问题。 以下是在调试抓包环境中遇到的一些问题和解决方法。 1、手机证书的安装 Charles在Mac…...
C++设计模式:桥接模式(Bridge)
什么是桥接模式? 桥接模式(Bridge Pattern)是一个用来解耦的设计模式,它将抽象层和实现层分离开,让它们可以独立变化。用最简单的话来说,就是让你能够改变抽象的功能和具体的实现,而不需要修改…...
spark3.x之后时间格式数据偶发报错org.apache.spark.SparkUpgradeException
3.x之后如果你去处理2.x生成的时间字符串数据,很容易遇到一个问题 Error operating ExecuteStatement: org.apache.spark.SparkUpgradeException: You may get a different result due to the upgrading of Spark 3.0: Fail to parse 20200725__cb90fcc3_8006_46…...
spring boot框架漏洞复现
spring - java开源框架有五种 Spring MVC、SpringBoot、SpringFramework、SpringSecurity、SpringCloud spring boot版本 版本1: 直接就在根下 / 版本2:根下的必须目录 /actuator/ 端口:9093 spring boot搭建 1:直接下载源码打包 2:运行编译好的jar包:actuator-testb…...
下载安装Android Studio
(一)Android Studio下载地址 https://developer.android.google.cn/studio 滑动到 点击下载文档 打开新网页 切换到english ; </style>导航区域代码 VUE代码 <template><view class"home"><!-- 导航区域 --><…...
uniapp-vue2引用了vue-inset-loader插件编译小程序报错
报错信息 Error: Vue packages version mismatch: - vue3.2.45 (D:\qjy-myApp\admin-app\node_modules\vue\index.js) - vue-template-compiler2.7.16 (D:\qjy-myApp\admin-app\node_modules\vue-template-compiler\package.json) This may cause things to work incorrectly.…...
Git命令大全(超详细)
Git 是一个分布式版本控制系统,用于跟踪计算机文件的更改,并协调多个用户之间的工作。下面是一份较为详细的 Git 命令大全,涵盖了从初始化仓库到日常使用中常见的操作。 1. 初始化与配置 设置用户信息: git config --global user.name &quo…...
【机器学习】机器学习学习笔记 - 监督学习 - 逻辑回归分类朴素贝叶斯分类支持向量机 SVM (可分类、可回归) - 04
逻辑回归分类 import numpy as np from sklearn import linear_modelX np.array([[4, 7], [3.5, 8], [3.1, 6.2], [0.5, 1], [1, 2], [1.2, 1.9], [6, 2], [5.7, 1.5], [5.4, 2.2]]) y np.array([0, 0, 0, 1, 1, 1, 2, 2, 2])# 逻辑回归分类器 # solver:求解器&a…...
常见的数据结构---数组、链表、栈的深入剖析
目录 一、数组(Array) 二、链表(Linked List) 三、栈(Stack) 四、总结 数据结构是算法的基石,是程序设计的核心基础。不同的数据结构适用于不同的场景和需求,选择合适的数据结构能…...
前端开发:构建高质量用户体验的全方位指南(含实际案例与示例)
前端开发:构建高质量用户体验的全方位指南(含实际案例与示例) 在当今数字化时代,前端技术不仅是网页和应用的门面,更是连接用户与数字世界的桥梁。一个高质量的前端开发项目不仅能够提升用户体验(UX&#…...
Istio_05_Istio架构
Istio_05_Istio架构 ArchitectureControl PlanePilotCitadelGalley Data PlaneSidecarIstio-proxyPilot-agentMetadta Exchange Ambient Architecture 如: Istio的架构(控制面、数据面) Gateway: Istio数据面的出/入口网关 Gateway分为: Ingress-gateway、Egress-gateway外部访…...
Linux应用开发之网络套接字编程(实例篇)
服务端与客户端单连接 服务端代码 #include <sys/socket.h> #include <sys/types.h> #include <netinet/in.h> #include <stdio.h> #include <stdlib.h> #include <string.h> #include <arpa/inet.h> #include <pthread.h> …...
从WWDC看苹果产品发展的规律
WWDC 是苹果公司一年一度面向全球开发者的盛会,其主题演讲展现了苹果在产品设计、技术路线、用户体验和生态系统构建上的核心理念与演进脉络。我们借助 ChatGPT Deep Research 工具,对过去十年 WWDC 主题演讲内容进行了系统化分析,形成了这份…...
OpenLayers 分屏对比(地图联动)
注:当前使用的是 ol 5.3.0 版本,天地图使用的key请到天地图官网申请,并替换为自己的key 地图分屏对比在WebGIS开发中是很常见的功能,和卷帘图层不一样的是,分屏对比是在各个地图中添加相同或者不同的图层进行对比查看。…...
什么是Ansible Jinja2
理解 Ansible Jinja2 模板 Ansible 是一款功能强大的开源自动化工具,可让您无缝地管理和配置系统。Ansible 的一大亮点是它使用 Jinja2 模板,允许您根据变量数据动态生成文件、配置设置和脚本。本文将向您介绍 Ansible 中的 Jinja2 模板,并通…...
uniapp 开发ios, xcode 提交app store connect 和 testflight内测
uniapp 中配置 配置manifest 文档:manifest.json 应用配置 | uni-app官网 hbuilderx中本地打包 下载IOS最新SDK 开发环境 | uni小程序SDK hbulderx 版本号:4.66 对应的sdk版本 4.66 两者必须一致 本地打包的资源导入到SDK 导入资源 | uni小程序SDK …...
uniapp 字符包含的相关方法
在uniapp中,如果你想检查一个字符串是否包含另一个子字符串,你可以使用JavaScript中的includes()方法或者indexOf()方法。这两种方法都可以达到目的,但它们在处理方式和返回值上有所不同。 使用includes()方法 includes()方法用于判断一个字…...
9-Oracle 23 ai Vector Search 特性 知识准备
很多小伙伴是不是参加了 免费认证课程(限时至2025/5/15) Oracle AI Vector Search 1Z0-184-25考试,都顺利拿到certified了没。 各行各业的AI 大模型的到来,传统的数据库中的SQL还能不能打,结构化和非结构的话数据如何和…...
【WebSocket】SpringBoot项目中使用WebSocket
1. 导入坐标 如果springboot父工程没有加入websocket的起步依赖,添加它的坐标的时候需要带上版本号。 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-websocket</artifactId> </dep…...
基于stm32F10x 系列微控制器的智能电子琴(附完整项目源码、详细接线及讲解视频)
注:文章末尾网盘链接中自取成品使用演示视频、项目源码、项目文档 所用硬件:STM32F103C8T6、无源蜂鸣器、44矩阵键盘、flash存储模块、OLED显示屏、RGB三色灯、面包板、杜邦线、usb转ttl串口 stm32f103c8t6 面包板 …...
背包问题双雄:01 背包与完全背包详解(Java 实现)
一、背包问题概述 背包问题是动态规划领域的经典问题,其核心在于如何在有限容量的背包中选择物品,使得总价值最大化。根据物品选择规则的不同,主要分为两类: 01 背包:每件物品最多选 1 次(选或不选&#…...
