踩坑日记 | 记一次流程图问题排查

踩坑日记:记一次流程图问题排查

标签: activiti | 流程

引言

今天排查了一个流程图问题,耗时2个小时终于解决,记录下来

现象

流程审批驳回报错:Unknown property used in expression: ${xxxx}
使用的是 activiti 流程

错误日志:

Error while closing command context
org.activiti.engine.ActivitiException: Unknown property used in expression: ${A0_LS_YCSHENPI}

流程图:
在这里插入图片描述

其中三条分支的配置分别为:
${path==‘P3’}
${path==‘P2’}
${action == ‘REFUSE’ || action == ‘REJECT’}

修改后的流程图:
在这里插入图片描述

其中三条分支的配置分别为:${action==‘PASS’&&path==‘P3’}
${action==‘PASS’&&path==‘P2’}
${action == ‘REFUSE’ || action == ‘REJECT’}

分析过程

完整日志:

提交时执行路径计算,taskId: 55438607,result: ProcessScriptExecuteResult(result=ProcessScriptExecuteResult.Result(path=P3, nextStepRoleIdList=[A0_LS_YCSHENPI], userId=null, nextStepSysFlag=false, nextTaskName=null), isSuccess=true, errMsg=null)
事务开始, transactionDefinition: PROPAGATION_REQUIRED,ISOLATION_DEFAULT
ActivitiGlobalTaskCompletedListener action: REJECT, taskId :55438607
ActivitiGlobalTaskCompletedListener over, taskId: 55438607
2024-07-12 08:49:24.003	
Error while closing command context
org.activiti.engine.ActivitiException: Unknown property used in expression: ${A0_LS_YCSHENPI}

通过完整的日志 以及打断点方式 了解了整个流程

后端接到驳回的请求之后不管是否驳回 都会先调用grovvy的脚本 计算一下 下一步的审批人

计算完成后再去根据action 判断走哪个流程

结果就是 计算后得到结果 Result(path=P3, nextStepRoleIdList=[A0_LS_YCSHENPI], userId=null, nextStepSysFlag=false, nextTaskName=null), isSuccess=true, errMsg=null)

但实际上 应该驳回或否决的路 ,结果走到了下一个人审批的路径

导致程序去bpmn中找对应的角色 找不到,最后报错

解决方案就是,使用action强制约束每条路径
${action==‘PASS’&&path==‘P3’}
${action==‘PASS’&&path==‘P2’}
${action == ‘REFUSE’ || action == ‘REJECT’}

最后问题解决。(长舒一口气)

总结

这是一个画流程图的坑

画流程图时需要注意:如果一个节点之后有多个分支,需要先试用 action 做好分流,再用path做进一步的分流。

相关推荐

  1. Python

    2024-07-14 07:22:03       31 阅读
  2. 【GO】排查 docker virtual size 过大问题

    2024-07-14 07:22:03       54 阅读
  3. Mysql加字段加不上问题排查过程

    2024-07-14 07:22:03       51 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-14 07:22:03       67 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-14 07:22:03       71 阅读
  3. 在Django里面运行非项目文件

    2024-07-14 07:22:03       58 阅读
  4. Python语言-面向对象

    2024-07-14 07:22:03       69 阅读

热门阅读

  1. [C++]类与对象

    2024-07-14 07:22:03       20 阅读
  2. 大模型日报 2024-07-13

    2024-07-14 07:22:03       20 阅读
  3. 家校管理系统

    2024-07-14 07:22:03       18 阅读
  4. 使用vllIm部署大语言模型

    2024-07-14 07:22:03       23 阅读
  5. 在Debian 7上安装和保护phpMyAdmin的方法

    2024-07-14 07:22:03       30 阅读
  6. Nginx 负载均衡详解

    2024-07-14 07:22:03       21 阅读
  7. Git常用命令

    2024-07-14 07:22:03       27 阅读
  8. 软设之访问者模式

    2024-07-14 07:22:03       19 阅读
  9. git 学术加速

    2024-07-14 07:22:03       24 阅读