springboot+activiti6,多人会审流程的实现(无序,有序)

本文主要是介绍springboot+activiti6,多人会审流程的实现(无序,有序),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

引导语:业务中一个节点可能需要多个人审批,也可能是多个人任意一个人审批即可,这块就会用到多人审核

一. 多人会审基本流程

  1. 多人并行会审,流程图如下: 

   2. 流程配置

Multi instance:

  • Sequence 设置流程为串行还是并行处理。
  • Loop cardinality 设置节点的循环次数。
  • Collection 设置处理人集合。
  • Element variable 设置一个处理人变量。
  • Completion condition 设置结束条件,在这里配置会签结束条件
  •  
  • nrOfInstances:实例总数
  • nrOfActiveInstances:当前活动的,比如,还没完成的,实例数量。 对于顺序执行的多实例,值一直为1。
  • nrOfCompletedInstances:已经完成实例的数目。

   可以通过execution.getVariable(x)方法获得这些变量。

   另外,每个创建的分支都会有分支级别的本地变量(比如,其他实例不可见, 不会保存到流程实例级别)

  • loopCounter:表示特定实例的在循环的索引值。可以使用activiti的elementIndexVariable属性修改loopCounter的变量名。
     

3.流程梳理

     多人并行会审,此处根据condition配置的变量来对节点流程进行内部走向,${nrOfCompletedInstances/nrOfInstances==1}代表所有的人全部通过则才会到下一个节点,如果是任意一个人会审通过则进入下一个节点,则修改表达式${nrOfCompletedInstances>0}

4.代码实现

    代码其实很简单,上一节的代码不变,在启动流程传参那块,key变成对应的userList,传入多人id数组即可

    @Overridepublic ProcessInstance getTask(String perid, String tempName, Map<String, Object> map){identityService.setAuthenticatedUserId(perid);// 开始流程  map内容set对应的审核用户ProcessInstance pi = runtimeService.startProcessInstanceByKey(tempName, map);// 查询当前任务return pi;}

传参如下:

Map<string,Object> map =Maps.newHashMap();List<String> userList = new ArrayList();userList.add("1");userList.add("2");map.put("userList",userList );

启动流程则可以用set的用户查询对应的任务,进行审核,代码上一节都有.流程代码公共方法,只是根据业务参数进行传参

以上流程为多人并行审核,如果是多人顺序审核,选中sequential,顺序发起流程则会根据set人的顺序进行任务审核,前一个审核完成才会到下一个人审核.

二. 多很会审加排他网关

  1.绘制流程图如下

 流程分析: 多人并行审核,发起流程,所有人同意则进行到下一个节点人审核,如果有一个人不同意则流程结束.这里用到了排他网关,非此即彼,根据审核结果条件来处理下个节点的流向.

2.首先一个审核用户,多人审核,全部通过或者有一个不通过,则用ifPass来辨别审核同意还是不同意,

completion condition配置如下${nrOfCompletedInstances/nrOfInstances==1|| ifPass>0},其他的配置如上,

排他网关连接线配置如下

 3.配置监听类

   @Overridepublic void notify(DelegateTask delegateTask) {String eventName = delegateTask.getEventName();// ActivitiEventType.PROCESS_STARTEDif ("create".endsWith(eventName)) {log.info("create=========");} else if ("assignment".endsWith(eventName)) {log.info("assignment========");} else if ("complete".endsWith(eventName)) {log.info("complete===========");Map<String, Object> map = delegateTask.getVariables();String ifPass = ObjectUtils.toString(map.get("ifPass"),"");if(StringUtils.isNoneBlank(ifPass) && ifPass.equals("0")){delegateTask.setVariable("ifPass",1);}else {delegateTask.setVariable("ifPass",0);}} else if ("delete".endsWith(eventName)) {log.info("delete=============");}// delegateTask 可以操作activiti引擎的一些东西}

4.流程启动运行,接口上一节代码不变.到此,基本业务流程也就实现了,对于项目中遇到的业务问题,可以借助监听类来实现复杂的业务流程,千变万化只要了解代码的编写方式,就能去实现多类型的复杂业务流程.

欢迎评论,留下您宝贵的建议,如果对你有用请记得点赞哦

这篇关于springboot+activiti6,多人会审流程的实现(无序,有序)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/398231

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

Security OAuth2 单点登录流程

单点登录(英语:Single sign-on,缩写为 SSO),又译为单一签入,一种对于许多相互关连,但是又是各自独立的软件系统,提供访问控制的属性。当拥有这项属性时,当用户登录时,就可以获取所有系统的访问权限,不用对每个单一系统都逐一登录。这项功能通常是以轻型目录访问协议(LDAP)来实现,在服务器上会将用户信息存储到LDAP数据库中。相同的,单一注销(single sign-off)就是指

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu