一 部署设计器java
代码:https://gitee.com/weim/flowable_demomysql
1. 将flowable-idm.war, flowable-modeler.war放到tomcat的webapps目录下,而后启动tomcatgit
2. 在浏览器中访问http://localhost:8080/flowable-modeler,用户名/密码:admin/test 登录,设计流程后,保存并导出文件。web
二 代码sql
1 建立流程引擎,而且部署一个流程定义浏览器
ProcessEngine processEngine = null; Map<String, String> userMap = new HashMap<>(); @Before public void Before() { userMap.put("11", "周六"); userMap.put("22", "周六大佬"); userMap.put("33", "管周六大佬"); userMap.put("44", "周天大佬"); userMap.put("55", "管周天大佬"); userMap.put("66", "大佬"); ProcessEngineConfiguration cfg = new StandaloneProcessEngineConfiguration() .setJdbcUrl("jdbc:mysql://localhost:3306/flowable?useSSL=true&serverTimezone=UTC&nullCatalogMeansCurrent=true") .setJdbcUsername("xxxx") .setJdbcPassword("xxxx") .setJdbcDriver("com.mysql.cj.jdbc.Driver") .setDatabaseSchemaUpdate(ProcessEngineConfiguration.DB_SCHEMA_UPDATE_TRUE); processEngine = cfg.buildProcessEngine(); } @Test public void Test01(){ // 获取Flowable服务 RepositoryService repositoryService = processEngine.getRepositoryService(); // 部署流程定义 Deployment deployment = repositoryService.createDeployment().addClasspathResource("bing_xing_wang_guan.bpmn20.xml").deploy(); //查找部署流程定义 ProcessDefinition processDefinition = repositoryService.createProcessDefinitionQuery().deploymentId(deployment.getId()).singleResult(); System.out.println(processDefinition.getName() + " " + processDefinition.getDeploymentId() + " " + processDefinition.getId()); }
2 一个完整的流程tomcat
@Test public void test02() { String processDefinitionId = "bing_xing_wang_guan_key:1:4"; RuntimeService runtimeService = processEngine.getRuntimeService(); TaskService taskService = processEngine.getTaskService(); Map<String, Object> variables = new HashMap<>(); variables.put("user", "11"); //启动流程 ProcessInstance processInstance = runtimeService.startProcessInstanceById(processDefinitionId, variables); System.out.println("processInstanceId = " + processInstance.getProcessInstanceId()); //查询周六下的任务 List<Task> tasks = taskService.createTaskQuery().taskAssignee("11").list(); queryTask(); //第一个并行网关 variables = new HashMap<>(); variables.put("oneManager", "22"); variables.put("twoManager", "44"); taskService.complete(tasks.get(0).getId(), variables); System.out.println("-----周六 结束了任务-----"); queryTask(); tasks = taskService.createTaskQuery().taskAssignee("22").list(); variables.put("oneNextManager", "33"); taskService.complete(tasks.get(0).getId(), variables); System.out.println("-----周六大佬 结束了任务-----"); queryTask(); tasks = taskService.createTaskQuery().taskAssignee("44").list(); variables.put("twoNextManager", "55"); taskService.complete(tasks.get(0).getId(), variables); System.out.println("-----周天大佬 结束了任务-----"); queryTask(); tasks = taskService.createTaskQuery().taskAssignee("33").list(); variables.put("nextManager", "66"); taskService.complete(tasks.get(0).getId(), variables); System.out.println("-----管周六大佬 结束了任务-----"); queryTask(); tasks = taskService.createTaskQuery().taskAssignee("55").list(); taskService.complete(tasks.get(0).getId(), variables); System.out.println("-----管周天大佬 结束了任务-----"); queryTask(); tasks = taskService.createTaskQuery().taskAssignee("66").list(); taskService.complete(tasks.get(0).getId()); System.out.println("-----大佬 结束了任务-----"); queryTask(); } private void queryTask() { TaskService taskService = processEngine.getTaskService(); System.out.println("---------------------------"); List<Task> tasks = taskService.createTaskQuery().taskAssignee("11").list(); System.out.println("周六有" + tasks.size() + " 个任务:"); tasks = taskService.createTaskQuery().taskAssignee("22").list(); System.out.println("周六大佬有" + tasks.size() + " 个任务:"); tasks = taskService.createTaskQuery().taskAssignee("33").list(); System.out.println("管周六大佬有" + tasks.size() + " 个任务:"); tasks = taskService.createTaskQuery().taskAssignee("44").list(); System.out.println("周天大佬有" + tasks.size() + " 个任务:"); tasks = taskService.createTaskQuery().taskAssignee("55").list(); System.out.println("管周天大佬有" + tasks.size() + " 个任务:"); tasks = taskService.createTaskQuery().taskAssignee("66").list(); System.out.println("大佬有" + tasks.size() + " 个任务:"); System.out.println("---------------------------"); }
完整流程的执行结果:app
processInstanceId = 12501 --------------------------- 周六有1 个任务: 周六大佬有0 个任务: 管周六大佬有0 个任务: 周天大佬有0 个任务: 管周天大佬有0 个任务: 大佬有0 个任务: --------------------------- -----周六 结束了任务----- --------------------------- 周六有0 个任务: 周六大佬有1 个任务: 管周六大佬有0 个任务: 周天大佬有1 个任务: 管周天大佬有0 个任务: 大佬有0 个任务: --------------------------- -----周六大佬 结束了任务----- --------------------------- 周六有0 个任务: 周六大佬有0 个任务: 管周六大佬有1 个任务: 周天大佬有1 个任务: 管周天大佬有0 个任务: 大佬有0 个任务: --------------------------- -----周天大佬 结束了任务----- --------------------------- 周六有0 个任务: 周六大佬有0 个任务: 管周六大佬有1 个任务: 周天大佬有0 个任务: 管周天大佬有1 个任务: 大佬有0 个任务: --------------------------- -----管周六大佬 结束了任务----- --------------------------- 周六有0 个任务: 周六大佬有0 个任务: 管周六大佬有0 个任务: 周天大佬有0 个任务: 管周天大佬有1 个任务: 大佬有0 个任务: --------------------------- -----管周天大佬 结束了任务----- --------------------------- 周六有0 个任务: 周六大佬有0 个任务: 管周六大佬有0 个任务: 周天大佬有0 个任务: 管周天大佬有0 个任务: 大佬有1 个任务: --------------------------- -----大佬 结束了任务----- --------------------------- 周六有0 个任务: 周六大佬有0 个任务: 管周六大佬有0 个任务: 周天大佬有0 个任务: 管周天大佬有0 个任务: 大佬有0 个任务: ---------------------------
3 驳回状况一: 同级别第一个或者第二个管理者驳回webapp
驳回状况二: 同级别第一个管理者结束了任务,同级别第二个管理者驳回ui
驳回状况三:管理者上级驳回
这里主要问题在于如何寻找上一个节点的activityId,采用了一种迂回的方式,保存到了变量里。
3.1 驳回状况一
@Test public void test03() { String processDefinitionId = "bing_xing_wang_guan_key:1:4"; RuntimeService runtimeService = processEngine.getRuntimeService(); TaskService taskService = processEngine.getTaskService(); Map<String, Object> variables = new HashMap<>(); variables.put("user", "11"); variables.put("11", null); //启动流程 ProcessInstance processInstance = runtimeService.startProcessInstanceById(processDefinitionId, variables); System.out.println("processInstanceId = " + processInstance.getProcessInstanceId()); //查询managers下的任务 List<Task> tasks = taskService.createTaskQuery().taskAssignee("11").list(); String lastActivityId = tasks.get(0).getTaskDefinitionKey(); queryTask(); //第一个并行网关 variables = new HashMap<>(); variables.put("22", lastActivityId); variables.put("44", lastActivityId); variables.put("oneManager", "22"); variables.put("twoManager", "44"); taskService.complete(tasks.get(0).getId(), variables); System.out.println("-----周六 结束了任务-----"); queryTask(); System.out.println("-----周天大佬 回退了任务-----"); List<Execution> executionList = runtimeService.createExecutionQuery().parentId(processInstance.getProcessInstanceId()).list(); List<String> currentExecutionIds = executionList.stream().map(item -> item.getId()).collect(Collectors.toList()); tasks = taskService.createTaskQuery().taskAssignee("44").list(); String targetActivityId = taskService.getVariable(tasks.get(0).getId(), "44").toString(); runtimeService.createChangeActivityStateBuilder() .moveExecutionsToSingleActivityId(currentExecutionIds, targetActivityId) .changeState(); queryTask(); }
驳回状况一执行结果:
processInstanceId = 15001 --------------------------- 周六有1 个任务: 周六大佬有0 个任务: 管周六大佬有0 个任务: 周天大佬有0 个任务: 管周天大佬有0 个任务: 大佬有0 个任务: --------------------------- -----周六 结束了任务----- --------------------------- 周六有0 个任务: 周六大佬有1 个任务: 管周六大佬有0 个任务: 周天大佬有1 个任务: 管周天大佬有0 个任务: 大佬有0 个任务: --------------------------- -----周天大佬 回退了任务----- --------------------------- 周六有1 个任务: 周六大佬有0 个任务: 管周六大佬有0 个任务: 周天大佬有0 个任务: 管周天大佬有0 个任务: 大佬有0 个任务: ---------------------------
3.2 驳回状况二
@Test public void test04() { String processDefinitionId = "bing_xing_wang_guan_key:1:4"; RuntimeService runtimeService = processEngine.getRuntimeService(); TaskService taskService = processEngine.getTaskService(); Map<String, Object> variables = new HashMap<>(); variables.put("user", "11"); variables.put("11", null); //启动流程 ProcessInstance processInstance = runtimeService.startProcessInstanceById(processDefinitionId, variables); System.out.println("processInstanceId = " + processInstance.getProcessInstanceId()); String processInstanceId = processInstance.getProcessInstanceId(); //查询managers下的任务 List<Task> tasks = taskService.createTaskQuery().taskAssignee("11").list(); String lastActivityId = tasks.get(0).getTaskDefinitionKey(); queryTask(); //第一个并行网关 variables = new HashMap<>(); variables.put("22", lastActivityId); variables.put("44", lastActivityId); variables.put("oneManager", "22"); variables.put("twoManager", "44"); taskService.complete(tasks.get(0).getId(), variables); System.out.println("-----周六 结束了任务-----"); queryTask(); tasks = taskService.createTaskQuery().taskAssignee("22").list(); lastActivityId = tasks.get(0).getTaskDefinitionKey(); variables.put("33", lastActivityId); variables.put("oneNextManager", "33"); taskService.complete(tasks.get(0).getId(), variables); System.out.println("-----周六大佬 结束了任务-----"); queryTask(); System.out.println("-----周天大佬 回退了任务-----"); List<Execution> executionList = runtimeService.createExecutionQuery().parentId(processInstanceId).list(); List<String> currentExecutionIds = executionList.stream().map(item -> item.getId()).collect(Collectors.toList()); tasks = taskService.createTaskQuery().taskAssignee("44").list(); String targetActivityId = taskService.getVariable(tasks.get(0).getId(), "44").toString(); runtimeService.createChangeActivityStateBuilder() .processInstanceId(processInstanceId) .moveExecutionsToSingleActivityId(currentExecutionIds, targetActivityId) .changeState(); queryTask(); }
驳回状况二执行结果:
processInstanceId = 20001 --------------------------- 周六有1 个任务: 周六大佬有0 个任务: 管周六大佬有0 个任务: 周天大佬有0 个任务: 管周天大佬有0 个任务: 大佬有0 个任务: --------------------------- -----周六 结束了任务----- --------------------------- 周六有0 个任务: 周六大佬有1 个任务: 管周六大佬有0 个任务: 周天大佬有1 个任务: 管周天大佬有0 个任务: 大佬有0 个任务: --------------------------- -----周六大佬 结束了任务----- --------------------------- 周六有0 个任务: 周六大佬有0 个任务: 管周六大佬有1 个任务: 周天大佬有1 个任务: 管周天大佬有0 个任务: 大佬有0 个任务: --------------------------- -----周天大佬 回退了任务----- --------------------------- 周六有1 个任务: 周六大佬有0 个任务: 管周六大佬有0 个任务: 周天大佬有0 个任务: 管周天大佬有0 个任务: 大佬有0 个任务: ---------------------------
3.3 驳回状况三
@Test public void test06() { String processDefinitionId = "bing_xing_wang_guan_key:1:4"; RuntimeService runtimeService = processEngine.getRuntimeService(); TaskService taskService = processEngine.getTaskService(); Map<String, Object> variables = new HashMap<>(); variables.put("user", "11"); variables.put("11", null); //启动流程 ProcessInstance processInstance = runtimeService.startProcessInstanceById(processDefinitionId, variables); System.out.println("processInstanceId = " + processInstance.getProcessInstanceId()); String processInstanceId = processInstance.getProcessInstanceId(); //查询managers下的任务 List<Task> tasks = taskService.createTaskQuery().taskAssignee("11").list(); String lastActivityId = tasks.get(0).getTaskDefinitionKey(); queryTask(); //第一个并行网关 variables = new HashMap<>(); variables.put("22", lastActivityId); variables.put("44", lastActivityId); variables.put("oneManager", "22"); variables.put("twoManager", "44"); taskService.complete(tasks.get(0).getId(), variables); System.out.println("-----周六 结束了任务-----"); queryTask(); tasks = taskService.createTaskQuery().taskAssignee("22").list(); lastActivityId = tasks.get(0).getTaskDefinitionKey(); variables.put("33", lastActivityId); variables.put("oneNextManager", "33"); taskService.complete(tasks.get(0).getId(), variables); System.out.println("-----周六大佬 结束了任务-----"); queryTask(); tasks = taskService.createTaskQuery().taskAssignee("33").list(); lastActivityId = tasks.get(0).getTaskDefinitionKey(); variables.put("nextManager", "66"); variables.put("66", lastActivityId); taskService.complete(tasks.get(0).getId(), variables); System.out.println("-----管周六大佬 结束了任务-----"); queryTask(); tasks = taskService.createTaskQuery().taskAssignee("44").list(); lastActivityId = tasks.get(0).getTaskDefinitionKey(); variables.put("55", lastActivityId); variables.put("twoNextManager", "55"); taskService.complete(tasks.get(0).getId(), variables); System.out.println("-----周天大佬 结束了任务-----"); queryTask(); tasks = taskService.createTaskQuery().taskAssignee("55").list(); lastActivityId = tasks.get(0).getTaskDefinitionKey(); Object variable = taskService.getVariable(tasks.get(0).getId(), "66"); if(variable != null) { lastActivityId = String.valueOf(variable) + "&&" + lastActivityId; } variables.put("66", lastActivityId); variables.put("nextManager", "66"); taskService.complete(tasks.get(0).getId(), variables); System.out.println("-----管周天大佬 结束了任务-----"); queryTask(); System.out.println("-----大佬 回退了任务-----"); List<Execution> executionList = runtimeService.createExecutionQuery().parentId(processInstanceId).list(); String currentActivityId02 = executionList.get(0).getActivityId(); tasks = taskService.createTaskQuery().taskAssignee("66").list(); String currentActivityId = runtimeService.getActiveActivityIds(tasks.get(0).getExecutionId()).get(0); String variable02 = taskService.getVariable(tasks.get(0).getId(), "66").toString(); List<String> targetActivityIds = Arrays.asList(variable02.split("&&")); runtimeService.createChangeActivityStateBuilder() .processInstanceId(processInstanceId) .moveSingleActivityIdToActivityIds(currentActivityId, targetActivityIds) .changeState(); queryTask(); }
驳回状况三执行结果:
processInstanceId = 25001 --------------------------- 周六有1 个任务: 周六大佬有0 个任务: 管周六大佬有0 个任务: 周天大佬有0 个任务: 管周天大佬有0 个任务: 大佬有0 个任务: --------------------------- -----周六 结束了任务----- --------------------------- 周六有0 个任务: 周六大佬有1 个任务: 管周六大佬有0 个任务: 周天大佬有1 个任务: 管周天大佬有0 个任务: 大佬有0 个任务: --------------------------- -----周六大佬 结束了任务----- --------------------------- 周六有0 个任务: 周六大佬有0 个任务: 管周六大佬有1 个任务: 周天大佬有1 个任务: 管周天大佬有0 个任务: 大佬有0 个任务: --------------------------- -----管周六大佬 结束了任务----- --------------------------- 周六有0 个任务: 周六大佬有0 个任务: 管周六大佬有0 个任务: 周天大佬有1 个任务: 管周天大佬有0 个任务: 大佬有0 个任务: --------------------------- -----周天大佬 结束了任务----- --------------------------- 周六有0 个任务: 周六大佬有0 个任务: 管周六大佬有0 个任务: 周天大佬有0 个任务: 管周天大佬有1 个任务: 大佬有0 个任务: --------------------------- -----管周天大佬 结束了任务----- --------------------------- 周六有0 个任务: 周六大佬有0 个任务: 管周六大佬有0 个任务: 周天大佬有0 个任务: 管周天大佬有0 个任务: 大佬有1 个任务: --------------------------- -----大佬 回退了任务----- --------------------------- 周六有0 个任务: 周六大佬有0 个任务: 管周六大佬有1 个任务: 周天大佬有0 个任务: 管周天大佬有1 个任务: 大佬有0 个任务: ---------------------------