前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >工作流引擎之activiti6流程节点自由跳转实现

工作流引擎之activiti6流程节点自由跳转实现

作者头像
lyb-geek
发布2018-08-16 16:20:52
10.8K1
发布2018-08-16 16:20:52
举报
文章被收录于专栏:Linyb极客之路Linyb极客之路

前言

在中国式的流程需求中,诸如驳回,退回功能需要进行流程跳转,比如领导审批不通过,退回到申请人。这种中国式的流程需求,可以通过以下三种方式实现

1、通过流程图设计,新增一条驳回连接线,并在连接中配置一些条件进行跳转。通常业务口更希望不需要再额外添加连接线就能实现跳转。 2、动态修改流程定义环节的连线,然后执行跳转,完成后再恢复流程定义。 这种方法可以实现动态跳转,不需要修改Activiti自身执行,但是会动态修改系统中的流程定义缓存对象。理论上这会出现一个多线程下,全局变量不安全的问题。单个Activiti流程引擎中,流程定义缓存对象是被所有线程共用的,当一个应用服务器同时收到两个不同流程实例、同个流程定义、同个环节的任务提交请求。a要求驳回,所以该线程动态修改了流程定义;与此同时,b要求正常流转,但是执行过程中,依据的流程定义已被修改,可能导致b也走向了驳回。 3、直接指定节点进行跳转,这是本篇介绍的重点

activiti6实现节点自由跳转

1、通过直接操作数据库进行修改,这种方法不推荐,容易出错。 2、通过自定义的command进行实现org.activiti.engine.impl.interceptor.Command接口

通过自定义的command进行实现

核心代码片段

代码语言:javascript
复制
@Override
    public Void execute(CommandContext commandContext) {
        System.out.println("跳转到目标流程节点:" + targetFlowNodeId);
        ExecutionEntityManager executionEntityManager = commandContext.getExecutionEntityManager();
        TaskEntityManager taskEntityManager = commandContext.getTaskEntityManager();
        // 获取当前任务的来源任务及来源节点信息
        TaskEntity taskEntity = taskEntityManager.findById(curTaskId);
        ExecutionEntity executionEntity = executionEntityManager.findById(taskEntity.getExecutionId());
        Process process = ProcessDefinitionUtil.getProcess(executionEntity.getProcessDefinitionId());
        // 删除当前节点
        taskEntityManager.deleteTask(taskEntity, "", true, true);
        // 获取要跳转的目标节点
        FlowElement targetFlowElement = process.getFlowElement(targetFlowNodeId);
        executionEntity.setCurrentFlowElement(targetFlowElement);
        ActivitiEngineAgenda agenda = commandContext.getAgenda();
        agenda.planContinueProcessInCompensation(executionEntity);

        return null;
    }
代码语言:javascript
复制
/**
     * 跳转到指定流程节点
     * 
     * @param curTaskId
     * @param targetFlowNodeId
     *            指定的流程节点ID 比如跳转<endEvent id="endevent1" name="End"></endEvent> ,则targetFlowNodeId为endevent1
     */
    public static void jump2TargetFlowNode(String curTaskId, String targetFlowNodeId) {
        managementService.executeCommand(new Jump2TargetFlowNodeCommand(curTaskId, targetFlowNodeId));
    }

节点自由跳转测试

流程图:

按这个流程图顺序,顺序执行为开始-->员工申请-->经理审批-->人事归档-->结束。当走到员工申请的下一节点时为经理审批,现在我们强行把员工申请的下一节点变成结束节点。

控制台输出

代码语言:javascript
复制
是否跳转指定流程...
yes
请输入要跳转的目标节点ID...
endevent1
Fri Aug 10 16:54:56 CST 2018 WARN: Establishing SSL connection without server's identity verification is not recommended. According to MySQL 5.5.45+, 5.6.26+ and 5.7.6+ requirements SSL connection must be established by default if explicit option isn't set. For compliance with existing applications not using SSL the verifyServerCertificate property is set to 'false'. You need either to explicitly disable SSL by setting useSSL=false, or set useSSL=true and provide truststore for server certificate verification.
跳转到目标流程节点:endevent1
Fri Aug 10 16:54:56 CST 2018 WARN: Establishing SSL connection without server's identity verification is not recommended. According to MySQL 5.5.45+, 5.6.26+ and 5.7.6+ requirements SSL connection must be established by default if explicit option isn't set. For compliance with existing applications not using SSL the verifyServerCertificate property is set to 'false'. You need either to explicitly disable SSL by setting useSSL=false, or set useSSL=true and provide truststore for server certificate verification.
----------------------------------流程实例流转-----------------------
Fri Aug 10 16:54:56 CST 2018 WARN: Establishing SSL connection without server's identity verification is not recommended. According to MySQL 5.5.45+, 5.6.26+ and 5.7.6+ requirements SSL connection must be established by default if explicit option isn't set. For compliance with existing applications not using SSL the verifyServerCertificate property is set to 'false'. You need either to explicitly disable SSL by setting useSSL=false, or set useSSL=true and provide truststore for server certificate verification.
活动ID:232508
流程实例ID:232501
活动名称:Start
办理人:null
开始时间:Fri Aug 10 16:54:39 CST 2018
结束时间:Fri Aug 10 16:54:39 CST 2018
=================================
活动ID:232509
流程实例ID:232501
活动名称:员工申请
办理人:applyUser
开始时间:Fri Aug 10 16:54:39 CST 2018
结束时间:Fri Aug 10 16:54:39 CST 2018
=================================
活动ID:237501
流程实例ID:232501
活动名称:End
办理人:null
开始时间:Fri Aug 10 16:54:56 CST 2018
结束时间:Fri Aug 10 16:54:56 CST 2018
=================================

上述跳转命令类的缺陷

只适用于常规节点的跳转,不支持分支节点的跳转、多实例节点的跳转以及并行节点的跳转

demo地址

https://github.com/lyb-geek/demo-activiti-freeJumpNode

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2018-08-12,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 Linyb极客之路 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 前言
  • activiti6实现节点自由跳转
    • 通过自定义的command进行实现
      • 节点自由跳转测试
        • 控制台输出
        • 上述跳转命令类的缺陷
        • demo地址
        相关产品与服务
        云数据库 MySQL
        腾讯云数据库 MySQL(TencentDB for MySQL)为用户提供安全可靠,性能卓越、易于维护的企业级云数据库服务。其具备6大企业级特性,包括企业级定制内核、企业级高可用、企业级高可靠、企业级安全、企业级扩展以及企业级智能运维。通过使用腾讯云数据库 MySQL,可实现分钟级别的数据库部署、弹性扩展以及全自动化的运维管理,不仅经济实惠,而且稳定可靠,易于运维。
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档