1.排他网关

说明:

1) 一个排他网关对应一个以上的顺序流

2) 由排他网关流出的顺序流都有个conditionExpression元素,在内部维护返回boolean类型的决策结果。

3) 决策网关只会返回一条结果。当流程执行到排他网关时,流程引擎会自动检索网关出口,从上到下检索如果发现第一条决策结果为true或者没有设置条件的(默认为成立),则流出。

4) 如果没有任何一个出口符合条件,则抛出异常

使用流程变量,设置连线的条件,并按照连线的条件执行工作流,如果没有条件符合的条件,则以默认的连线离开。例如

则执行连线:

如果使用流程变量设置

则执行连线:

2.并行网关

说明:

1) 一个流程中流程实例只有1个,执行对象有多个

2) 并行网关的功能是基于进入和外出的顺序流的:

分支(fork): 并行后的所有外出顺序流,为每个顺序流都创建一个并发分支。

汇聚(join): 所有到达并行网关,在此等待的进入分支, 直到所有进入顺序流的分支都到达以后, 流程就会通过汇聚网关。

3) 并行网关的进入和外出都是使用相同节点标识

4) 如果同一个并行网关有多个进入和多个外出顺序流, 它就同时具有分支和汇聚功能。 这时,网关会先汇聚所有进入的顺序流,然后再切分成多个并行分支。

5) 并行网关不会解析条件。 即使顺序流中定义了条件,也会被忽略。

6)并行网关不需要是“平衡的”(比如, 对应并行网关的进入和外出节点数目不一定相等)。如图中标示是合法的:

3.开始活动节点

流程图:

3.1部署流程定义+启动流程实例+查询流程实例+查询历史流程实例

  1. ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();
  2.  
  3. /**
  4. * 部署流程定义
  5. */
  6. @Test
  7. public void deployProcessDefinition() {
  8. InputStream inputStream = this.getClass().getResourceAsStream("start.bpmn");
  9. InputStream inputStreamPic = this.getClass().getResourceAsStream("start.png");
  10. Deployment deploy = processEngine.getRepositoryService().createDeployment().name("开始节点")
  11. .addInputStream("start.bpmn", inputStream)
  12. .addInputStream("start.png", inputStreamPic)
  13. .deploy();
  14. System.out.println("部署ID:"+deploy.getId());
  15. System.out.println("部署名称:"+deploy.getName());
  16. }
  17.  
  18. /**
  19. * 启动流程实例
  20. */
  21. @Test
  22. public void startProcessInstance() {
  23. String processDefinitionKey = "start";
  24. ProcessInstance startProcessInstanceByKey = processEngine.getRuntimeService().startProcessInstanceByKey(processDefinitionKey);
  25. System.out.println("流程实例ID:"+startProcessInstanceByKey.getId());
  26. System.out.println("流程定义ID:"+startProcessInstanceByKey.getProcessDefinitionId());
  27. /**判断流程是否接受,查询正在执行的执行对象表**/
  28. ProcessInstance pi = processEngine.getRuntimeService()
  29. .createProcessInstanceQuery()
  30. .processInstanceId(startProcessInstanceByKey.getId())
  31. .singleResult();
  32. //说明流程实例结束了
  33. if (pi == null) {
  34. /**查询历史,获取流程的相关信息**/
  35. HistoricProcessInstance hpi = processEngine.getHistoryService()
  36. .createHistoricProcessInstanceQuery()
  37. .processInstanceId(startProcessInstanceByKey.getId())
  38. .singleResult();
  39. System.out.println(hpi.getId()+" "+hpi.getStartTime()+" "+hpi.getEndTime());
  40. }
  41.  
  42. }
  43. }

1):结束节点没有出口

2):其他节点有一个或多个出口。

如果有一个出口,则代表是一个单线流程

如果有多个出口,则代表是开启并发流程

 4.接收任务

接收任务是一个简单任务,它会等待对应消息的到达。 当前,官方只实现了这个任务的java语义。 当流程达到接收任务,流程状态会保存到数据库中。

在任务创建后,意味着流程会进入等待状态, 直到引擎接收了一个特定的消息, 这会触发流程穿过接收任务继续执行。

流程图:

4.1 部署流程定义+启动流程实例

  1. /**
  2. * ReceiceTask任务,机器自动完成的任务
  3. * 只会在act_ru_execution表中产生一条数据
  4. * @throws Exception
  5. */
  6.  
  7. @Test
  8. public void testExecution() throws Exception {
  9. // 1 发布流程
  10. InputStream inputStreamBpmn = this.getClass().getResourceAsStream("receiveTask.bpmn");
  11. InputStream inputStreamPng = this.getClass().getResourceAsStream("receiveTask.png");
  12. processEngine.getRepositoryService()//
  13. .createDeployment()//
  14. .addInputStream("receiveTask.bpmn", inputStreamBpmn)//
  15. .addInputStream("receiveTask.png", inputStreamPng)//
  16. .deploy();
  17.  
  18. // 2 启动流程
  19. ProcessInstance pi = processEngine.getRuntimeService()//
  20. .startProcessInstanceByKey("receiveTaskDemo");
  21. System.out.println("pid:" + pi.getId());
  22. String pid = pi.getId();
  23.  
  24. // 3查询是否有一个执行对象在描述”汇总当日销售额“
  25. Execution e1 = processEngine.getRuntimeService()//
  26. .createExecutionQuery()//
  27. .processInstanceId(pid)//
  28. .activityId("汇总当日销售额")//
  29. .singleResult();
  30.  
  31. // 4执行一堆逻辑,并设置流程变量
  32. Map<String,Object> vars = new HashMap<String, Object>();
  33. vars.put("当日销售额", 10000);
  34. // 5流程向后执行一步:往后推移e1,使用signal给流程引擎信号,告诉他当前任务已经完成了,可以往后执行
  35. processEngine.getRuntimeService()
  36. .signal(e1.getId(),vars);
  37.  
  38. // 6判断当前流程是否在”给老板发短信“节点
  39. Execution e2 = processEngine.getRuntimeService()//
  40. .createExecutionQuery()//
  41. .processInstanceId(pid)//
  42. .activityId("给总经理发短信")//
  43. .singleResult();
  44.  
  45. // 7获取流程变量
  46. Integer money = (Integer) processEngine.getRuntimeService()//
  47. .getVariable(e2.getId(), "当日销售额");
  48. System.out.println("老板,今天赚了" +money);
  49. // 8向后执行一步:任务完成,往后推移”给老板发短信“任务
  50. processEngine.getRuntimeService()//
  51. .signal(e2.getId());
  52.  
  53. // 9查询流程状态
  54. pi = processEngine.getRuntimeService()//
  55. .createProcessInstanceQuery()//
  56. .processInstanceId(pid)//
  57. .singleResult();
  58. if(pi==null){
  59. System.out.println("流程正常执行!!!,已经结束了");
  60. }
  61. }

说明:

1) 当前任务(一般指机器自动完成,但需要耗费一定时间的工作)完成后,向后推移流程,可以调用runtimeService.signal(executionId),传递接收执行对象的id。

5. 用户任务(userTask,即用户操作的任务)

5.1 个人任务

5.1.1 流程图

5.1.2 分配个人任务方式一(直接指定办理人)

流程图中任务节点的配置

测试代码:

  1. ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();
  2. /**
  3. * 部署流程定义
  4. */
  5. @Test
  6. public void deployProcessDefinition() {
  7. InputStream inputStream = this.getClass().getResourceAsStream("personalTask.bpmn");
  8. InputStream inputStreamPic = this.getClass().getResourceAsStream("personalTask.png");
  9. Deployment deploy = processEngine.getRepositoryService().createDeployment().name("个人任务")
  10. .addInputStream("personalTask.bpmn", inputStream)
  11. .addInputStream("personalTask.png", inputStreamPic)
  12. .deploy();
  13. System.out.println("部署ID:"+deploy.getId());
  14. System.out.println("部署名称:"+deploy.getName());
  15. }
  16. /**
  17. * 启动流程实例,设置流程变量+获取流程变量+向后执行一步
  18. */
  19. @Test
  20. public void startProcessInstance() {
  21. String processDefinitionKey = "personTask";
  22. ProcessInstance startProcessInstanceByKey = processEngine.getRuntimeService().startProcessInstanceByKey(processDefinitionKey);
  23. System.out.println("流程实例ID:"+startProcessInstanceByKey.getId());
  24. System.out.println("流程定义ID:"+startProcessInstanceByKey.getProcessDefinitionId());
  25. }
  26. /**
  27. * 查询个人任务
  28. */
  29. @Test
  30. public void findMyProcess() {
  31. String assignee = "张三丰";
  32. List<Task> list = processEngine.getTaskService().createTaskQuery().taskAssignee(assignee).list();
  33. if (list != null && list.size() > 0) {
  34. for (Task task : list) {
  35. System.out.println("任务ID:"+task.getId());
  36. System.out.println("任务名称:"+task.getName());
  37. System.out.println("任务创建时间:"+task.getCreateTime());
  38. System.out.println("任务办理人:"+task.getAssignee());
  39. System.out.println("流程实例ID:"+task.getProcessInstanceId());
  40. System.out.println("执行对象ID:"+task.getExecutionId());
  41. System.out.println("流程定义ID:"+task.getProcessDefinitionId());
  42. }
  43. }
  44. }
  45. /**
  46. * 完成个人任务
  47. */
  48. @Test
  49. public void completMyProcess() {
  50. String taskId = "5304";
  51. Map<String, Object> map = new HashMap<>();
  52. processEngine.getTaskService().complete(taskId);
  53. }
  54. }

5.1.3 分配个人任务方式二(使用流程变量)

流程图中任务节点的配置

测试代码

  1. ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();
  2. /**
  3. * 部署流程定义
  4. */
  5. @Test
  6. public void deployProcessDefinition() {
  7. InputStream inputStream = this.getClass().getResourceAsStream("personalTask.bpmn");
  8. InputStream inputStreamPic = this.getClass().getResourceAsStream("personalTask.png");
  9. Deployment deploy = processEngine.getRepositoryService().createDeployment().name("个人任务")
  10. .addInputStream("personalTask.bpmn", inputStream)
  11. .addInputStream("personalTask.png", inputStreamPic)
  12. .deploy();
  13. System.out.println("部署ID:"+deploy.getId());
  14. System.out.println("部署名称:"+deploy.getName());
  15. }
  16. /**
  17. * 启动流程实例,设置流程变量+获取流程变量+向后执行一步
  18. */
  19. @Test
  20. public void startProcessInstance() {
  21. String processDefinitionKey = "personTask";
  22. Map<String, Object> variables = new HashMap<>();
  23. variables.put("userId", "周芷若");
  24. ProcessInstance startProcessInstanceByKey = processEngine.getRuntimeService()
  25. .startProcessInstanceByKey(processDefinitionKey,variables);//在启动实例时,设置流程变量
  26. System.out.println("流程实例ID:"+startProcessInstanceByKey.getId());
  27. System.out.println("流程定义ID:"+startProcessInstanceByKey.getProcessDefinitionId());
  28. }
  29. /**
  30. * 查询个人任务
  31. */
  32. @Test
  33. public void findMyProcess() {
  34. String assignee = "张三丰";
  35. List<Task> list = processEngine.getTaskService().createTaskQuery().taskAssignee(assignee).list();
  36. if (list != null && list.size() > 0) {
  37. for (Task task : list) {
  38. System.out.println("任务ID:"+task.getId());
  39. System.out.println("任务名称:"+task.getName());
  40. System.out.println("任务创建时间:"+task.getCreateTime());
  41. System.out.println("任务办理人:"+task.getAssignee());
  42. System.out.println("流程实例ID:"+task.getProcessInstanceId());
  43. System.out.println("执行对象ID:"+task.getExecutionId());
  44. System.out.println("流程定义ID:"+task.getProcessDefinitionId());
  45. }
  46. }
  47. }
  48. /**
  49. * 完成个人任务
  50. */
  51. @Test
  52. public void completMyProcess() {
  53. String taskId = "5605";
  54. Map<String, Object> map = new HashMap<>();
  55. processEngine.getTaskService().complete(taskId);
  56. }

5.1.4 分配个人任务方式三(使用类)

1.流程图中任务节点的配置

2.TaskListenerImpl类,用来设置任务的办理人

  1. /**
  2. * 用来指定任务的办理人
  3. */
  4. @Override
  5. public void notify(DelegateTask delegateTask) {
  6. // TODO Auto-generated method stub
  7. //指定个人任务的办理人,也可以指定组任务的办理人
  8. //个人任务通过类去查询数据库,将下一个任务的办理人查询获取,然后通过setAssignee()方法指定任务的办理人
  9. delegateTask.setAssignee("灭绝师太");
  10.  
  11. }

3.测试代码

  1. ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();
  2. /**
  3. * 部署流程定义
  4. */
  5. @Test
  6. public void deployProcessDefinition() {
  7. InputStream inputStream = this.getClass().getResourceAsStream("personalTask.bpmn");
  8. InputStream inputStreamPic = this.getClass().getResourceAsStream("personalTask.png");
  9. Deployment deploy = processEngine.getRepositoryService().createDeployment().name("个人任务")
  10. .addInputStream("personalTask.bpmn", inputStream)
  11. .addInputStream("personalTask.png", inputStreamPic)
  12. .deploy();
  13. System.out.println("部署ID:"+deploy.getId());
  14. System.out.println("部署名称:"+deploy.getName());
  15. }
  16. /**
  17. * 启动流程实例,设置流程变量+获取流程变量+向后执行一步
  18. */
  19. @Test
  20. public void startProcessInstance() {
  21. String processDefinitionKey = "personTask";
  22. /*Map<String, Object> variables = new HashMap<>();
  23. variables.put("userId", "周芷若");*/
  24. ProcessInstance startProcessInstanceByKey = processEngine.getRuntimeService()
  25. .startProcessInstanceByKey(processDefinitionKey);//在启动实例时,设置流程变量
  26. System.out.println("流程实例ID:"+startProcessInstanceByKey.getId());
  27. System.out.println("流程定义ID:"+startProcessInstanceByKey.getProcessDefinitionId());
  28. }
  29.  
  30.    /**可以分配个人任务从一个人到另一个人(认领任务)**/
        @Test
        public void setAssigneeTask() {
            //任务ID
            String taskId = "6104";
            //指定的办理人
            String userId = "张翠山";
            processEngine.getTaskService()
                         .setAssignee(taskId, userId);
        }

说明:

1) 在类中使用delegateTask.setAssignee(assignee);的方式分配个人任务的办理人,此时张无忌是下一个任务的办理人

2) 通过processEngine.getTaskService().setAssignee(taskId, userId);将个人任务从一个人分配给另一个人,此时张无忌不再是下一个任务的办理人,而换成了周芷若

3) 在开发中,可以将每一个任务的办理人规定好,例如张三的领导是李四,李四的领导是王五,这样张三提交任务,就可以查询出张三的领导是李四,通过类的方式设置下一个任务的办理人

5.1.5 总结

个人任务及三种分配方式:

1:在taskProcess.bpmn中直接写 assignee=“张三丰"

2:在taskProcess.bpmn中写 assignee=“#{userID}”,变量的值要是String的。

使用流程变量指定办理人

3,使用TaskListener接口,要使类实现该接口,在类中定义:

delegateTask.setAssignee(assignee);// 指定个人任务的办理人

 使用任务ID和办理人重新指定办理人:

processEngine.getTaskService()//

.setAssignee(taskId, userId);

6 组任务

6.1 流程图

6.2 分配组任务方式一(直接指定办理人)

1.流程图中任务节点的配置

2.测试代码:

  1. ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();
  2.  
  3. /**
  4. * 部署流程定义
  5. */
  6. @Test
  7. public void deployProcessDefinition() {
  8. InputStream inputStream = this.getClass().getResourceAsStream("groupTask.bpmn");
  9. InputStream inputStream2 = this.getClass().getResourceAsStream("groupTask.png");
  10. Deployment deploy = processEngine.getRepositoryService().createDeployment().name("组任务")
  11. .addInputStream("groupTask.bpmn", inputStream)
  12. .addInputStream("groupTask.png", inputStream2)
  13. .deploy();
  14. System.out.println("部署ID:"+deploy.getId());
  15. System.out.println("部署名称:"+deploy.getName());
  16.  
  17. }
  18. /**
  19. * 启动流程实例
  20. */
  21. @Test
  22. public void startProcessInstance() {
  23. String processDefinitionKey = "groupTask";
  24. ProcessInstance startProcessInstanceByKey = processEngine.getRuntimeService().startProcessInstanceByKey(processDefinitionKey);
  25. System.out.println("流程实例ID:"+startProcessInstanceByKey.getId());
  26. System.out.println("流程定义ID:"+startProcessInstanceByKey.getProcessDefinitionId());
  27. }
  28. /**
  29. * 查询当前人的组任务
  30. */
  31. @Test
  32. public void findMyGroupProcess() {
  33. String candidateUser = "小A";
  34. List<Task> list = processEngine.getTaskService().createTaskQuery()
  35. .taskCandidateUser(candidateUser)
  36. .orderByTaskCreateTime().desc().list();
  37. if (list != null && list.size() > 0) {
  38. for (Task task : list) {
  39. System.out.println("任务ID:"+task.getId());
  40. System.out.println("任务名称:"+task.getName());
  41. System.out.println("任务创建时间:"+task.getCreateTime());
  42. System.out.println("任务办理人:"+task.getAssignee());
  43. System.out.println("流程实例ID:"+task.getProcessInstanceId());
  44. System.out.println("执行对象ID:"+task.getExecutionId());
  45. System.out.println("流程定义ID:"+task.getProcessDefinitionId());
  46. }
  47. }
  48.  
  49. }
  50. /**
  51. * 查询正在执行的组任务办理人表
  52. */
  53. @Test
  54. public void findRunPersonTask() {
  55. String taskId = "7104";
  56. List<IdentityLink> list = processEngine.getTaskService()
  57. .getIdentityLinksForTask(taskId);
  58. if (list != null && list.size() > 0) {
  59. for (IdentityLink identityLink : list) {
  60. System.out.println(identityLink.getTaskId()+" "+identityLink.getType()+" "+identityLink.getUserId()+" "+identityLink.getProcessInstanceId());
  61. }
  62. }
  63. }
  64. /**
  65. * 查询历史的组任务办理人表
  66. */
  67. @Test
  68. public void findHistoryPersonTask() {
  69. String processInstanceId = "7101";
  70. List<HistoricIdentityLink> list = processEngine.getHistoryService()
  71. .getHistoricIdentityLinksForProcessInstance(processInstanceId);
  72. if (list != null && list.size() > 0) {
  73. for (HistoricIdentityLink hil : list) {
  74. System.out.println(hil.getTaskId()+" "+hil.getType()+" "+hil.getUserId()+" "+hil.getProcessInstanceId());
  75. }
  76. }
  77. }
  78. /**
  79. * 拾取任务,将组任务分给个人任务,指定任务的办理人字段
  80. */
  81. @Test
  82. public void claim() {
  83. String taskId = "7104";
  84. String userId = "小A";
  85. //分配个人任务(可以是组任务中的成员,也可以是非组任务的成员)
  86. processEngine.getTaskService().claim(taskId, userId);
  87. }
  88. /**
  89. * 拾取任务,将个人任务回退到组任务,数据执勤一定是个组任务
  90. */
  91. @Test
  92. public void setAssginee() {
  93. String taskId = "7104";
  94. String userId = "大F";
  95. //分配个人任务(可以是组任务中的成员,也可以是非组任务的成员)
  96. processEngine.getTaskService().setAssignee(taskId, null);
  97. }
  98. /**
  99. * 向组任务添加成员
  100. */
  101. @Test
  102. public void addGroupUser() {
  103. String taskId = "7104";
  104. String userId = "大H";
  105. processEngine.getTaskService().addCandidateUser(taskId, userId);
  106. }
  107. /**
  108. * 向组任务删除成员
  109. */
  110. @Test
  111. public void delGroupUser() {
  112. String taskId = "7104";
  113. String userId = "大H";
  114. processEngine.getTaskService().deleteCandidateUser(taskId, userId);
  115. }
  116. /**
  117. * 完成任务
  118. */
  119. @Test
  120. public void completProcessTask() {
  121. String taskId = "7104";
  122. processEngine.getTaskService().complete(taskId);
  123. }

说明:

1) 小A,小B,小C,小D是组任务的办理人

2) 但是这样分配组任务的办理人不够灵活,因为项目开发中任务的办理人不要放置XML文件中。

3) act_ru_identitylink表存放任务的办理人,包括个人任务和组任务,表示正在执行的任务

4) act_hi_identitylink表存放任务的办理人,包括个人任务和组任务,表示历史任务

区别在于:如果是个人任务TYPE的类型表示participant(参与者)

如果是组任务TYPE的类型表示candidate(候选者)和participant(参与者)

6.2 分配个人任务方式二(使用流程变量)

1.流程图中任务节点的配置

2.测试代码

  1. /**
  2. * 部署流程定义
  3. */
  4. @Test
  5. public void deployProcessDefinition() {
  6. InputStream inputStream = this.getClass().getResourceAsStream("groupTask.bpmn");
  7. InputStream inputStream2 = this.getClass().getResourceAsStream("groupTask.png");
  8. Deployment deploy = processEngine.getRepositoryService().createDeployment().name("组任务")
  9. .addInputStream("groupTask.bpmn", inputStream)
  10. .addInputStream("groupTask.png", inputStream2)
  11. .deploy();
  12. System.out.println("部署ID:"+deploy.getId());
  13. System.out.println("部署名称:"+deploy.getName());
  14.  
  15. }
  16. /**
  17. * 启动流程实例
  18. */
  19. @Test
  20. public void startProcessInstance() {
  21. String processDefinitionKey = "groupTask";
  22. Map<String, Object> variables = new HashMap<>();
  23. variables.put("userIds", "大大,中中,小小");
  24. ProcessInstance startProcessInstanceByKey = processEngine.getRuntimeService().startProcessInstanceByKey(processDefinitionKey,variables);
  25. System.out.println("流程实例ID:"+startProcessInstanceByKey.getId());
  26. System.out.println("流程定义ID:"+startProcessInstanceByKey.getProcessDefinitionId());
  27. }
  28. /**
  29. * 拾取任务,将组任务分给个人任务,指定任务的办理人字段
  30. */
  31. @Test
  32. public void claim() {
  33. String taskId = "7805";
  34. String userId = "大大";
  35. //分配个人任务(可以是组任务中的成员,也可以是非组任务的成员)
  36. processEngine.getTaskService().claim(taskId, userId);
  37. }
  38. /**
  39. * 完成任务
  40. */
  41. @Test
  42. public void completProcessTask() {
  43. String taskId = "7805";
  44. processEngine.getTaskService().complete(taskId);
  45. }

说明:

1) 大大,中中,小小是组任务的办理人

在开发中,可以在页面中指定下一个组任务的办理人,通过流程变量设置下一个任务的办理人

6.2 分配个人任务方式三(使用类)

1.流程图中任务节点的配置

2.TaskListenerImpl类,用来设置任务的办理人

  1. @Override
  2. public void notify(DelegateTask delegateTask) {
  3. // TODO Auto-generated method stub
  4. //组任务:
  5. delegateTask.addCandidateUser("郭靖");
  6. delegateTask.addCandidateUser("黄蓉");
  7. }

3.测试代码

  1. /**
  2. * 部署流程定义
  3. */
  4. @Test
  5. public void deployProcessDefinition() {
  6. InputStream inputStream = this.getClass().getResourceAsStream("groupTask.bpmn");
  7. InputStream inputStream2 = this.getClass().getResourceAsStream("groupTask.png");
  8. Deployment deploy = processEngine.getRepositoryService().createDeployment().name("组任务")
  9. .addInputStream("groupTask.bpmn", inputStream)
  10. .addInputStream("groupTask.png", inputStream2)
  11. .deploy();
  12. System.out.println("部署ID:"+deploy.getId());
  13. System.out.println("部署名称:"+deploy.getName());
  14.  
  15. }
  16. /**
  17. * 启动流程实例
  18. */
  19. @Test
  20. public void startProcessInstance() {
  21. String processDefinitionKey = "groupTask";
  22. /*Map<String, Object> variables = new HashMap<>();
  23. variables.put("userIds", "大大,中中,小小");*/
  24. ProcessInstance startProcessInstanceByKey = processEngine.getRuntimeService().startProcessInstanceByKey(processDefinitionKey);
  25. System.out.println("流程实例ID:"+startProcessInstanceByKey.getId());
  26. System.out.println("流程定义ID:"+startProcessInstanceByKey.getProcessDefinitionId());
  27. }
  28. /**
  29. * 查询当前人的组任务
  30. */
  31. @Test
  32. public void findMyGroupProcess() {
  33. String candidateUser = "郭靖";
  34. List<Task> list = processEngine.getTaskService().createTaskQuery()
  35. .taskCandidateUser(candidateUser)
  36. .orderByTaskCreateTime().desc().list();
  37. if (list != null && list.size() > 0) {
  38. for (Task task : list) {
  39. System.out.println("任务ID:"+task.getId());
  40. System.out.println("任务名称:"+task.getName());
  41. System.out.println("任务创建时间:"+task.getCreateTime());
  42. System.out.println("任务办理人:"+task.getAssignee());
  43. System.out.println("流程实例ID:"+task.getProcessInstanceId());
  44. System.out.println("执行对象ID:"+task.getExecutionId());
  45. System.out.println("流程定义ID:"+task.getProcessDefinitionId());
  46. }
  47. }
  48.  
  49. }
  50. /**
  51. * 拾取任务,将组任务分给个人任务,指定任务的办理人字段
  52. */
  53. @Test
  54. public void claim() {
  55. String taskId = "8104";
  56. String userId = "郭靖";
  57. //分配个人任务(可以是组任务中的成员,也可以是非组任务的成员)
  58. processEngine.getTaskService().claim(taskId, userId);
  59. }
  60. /**
  61. * 完成任务
  62. */
  63. @Test
  64. public void completProcessTask() {
  65. String taskId = "8104";
  66. processEngine.getTaskService().complete(taskId);
  67. }

说明:

1) 在类中使用delegateTask.addCandidateUser (userId);的方式分配组任务的办理人,此时孙悟空和猪八戒是下一个任务的办理人。

2) 通过processEngine.getTaskService().claim (taskId, userId);将组任务分配给个人任务,也叫认领任务,即指定某个人去办理这个任务,此时由如来去办理任务。

注意:认领任务的时候,可以是组任务成员中的人,也可以不是组任务成员的人,此时通过Type的类型为participant来指定任务的办理人

3) addCandidateUser()即向组任务添加成员,deleteCandidateUser()即删除组任务的成员。

4) 在开发中,可以将每一个任务的办理人规定好,例如张三的领导是李四和王五,这样张三提交任务,由李四或者王五去查询组任务,可以看到对应张三的申请,李四或王五再通过认领任务(claim)的方式,由某个人去完成这个任务。

6.2 总结

组任务及三种分配方式:

1:在taskProcess.bpmn中直接写 candidate-users=“小A,小B,小C,小D"

2:在taskProcess.bpmn中写 candidate-users =“#{userIDs}”,变量的值要是String的。

使用流程变量指定办理人

Map<String, Object> variables = new HashMap<String, Object>();

variables.put("userIDs", "大大,小小,中中");

3,使用TaskListener接口,使用类实现该接口,在类中定义:

//添加组任务的用户

delegateTask.addCandidateUser(userId1);

delegateTask.addCandidateUser(userId2);

组任务分配给个人任务(认领任务):

processEngine.getTaskService().claim(taskId, userId);

个人任务分配给组任务:

processEngine.getTaskService(). setAssignee(taskId, null);

向组任务添加人员:

processEngine.getTaskService().addCandidateUser(taskId, userId);

向组任务删除人员:

processEngine.getTaskService().deleteCandidateUser(taskId, userId);

个人任务和组任务存放办理人对应的表:

act_ru_identitylink表存放任务的办理人,包括个人任务和组任务,表示正在执行的任务

act_hi_identitylink表存放任务的办理人,包括个人任务和组任务,表示历史任务

区别在于:如果是个人任务TYPE的类型表示participant(参与者)

如果是组任务TYPE的类型表示candidate(候选者)和participant(参与者)

Activiti学习记录(五)的更多相关文章

  1. Activiti学习记录(二)

    1.初始化数据库 使用工作流引擎创建23张表 public class TestActiviti { /** * 使用代码创建工作流需要的23张表 */ @Test public void creat ...

  2. Activiti学习记录(一)

    1.工作流的概念 工作流(Workflow),就是“业务过程的部分或整体在计算机应用环境下的自动化”,它主要解决的是“使在多个参与者之间按照某种预定义的规则传递文档.信息或任务的过程自动进行,从而实现 ...

  3. Linux 学习记录 五(软件的安装升级).

    一.gcc gcc是Linux上面最标准的C语言的编译程序,用来源代码的编译链接. gcc -c hello.c 编译产生目标文件hello.o gcc -O hello.c 编译产生目标文件,并进行 ...

  4. leveldb 学习记录(五)SSTable格式介绍

    本节主要记录SSTable的结构 为下一步代码阅读打好基础,考虑到已经有大量优秀博客解析透彻 就不再编写了 这里推荐 https://blog.csdn.net/tankles/article/det ...

  5. Ansible学习记录五:PlayBook学习

    0.介绍 Playbooks 是 Ansible 管理配置.部署应用和编排的语言,可以使用 Playbooks 来描述你想在远程主机执行的策略或者执行的一组步骤过程等 类似于一组任务集,定义好像项目, ...

  6. Linux 学习记录五(软件的安装升级).

    一.gcc gcc是Linux上面最标准的C语言的编译程序,用来源代码的编译链接. gcc -c hello.c 编译产生目标文件hello.o gcc -O hello.c 编译产生目标文件,并进行 ...

  7. Spring学习记录(五)---bean的作用域scope

    作用域:singleton:单例,整个应用中只创建一个实例(默认) prototype:原型,每次注入时都新建一个实例 session:会话,每个会话创建一个实例 request:请求,每个请求创建一 ...

  8. zeromq学习记录(五)vc下多线程

    /************************************************************** 技术博客 http://www.cnblogs.com/itdef/   ...

  9. LoadRunner11学习记录五 -- 错误提示分析

    LoadRunner测试结果具体分析: 一.错误提示分析  分析实例: 1.Error: Failed to connect to server “172.17.7.230″: [10060] Con ...

随机推荐

  1. 关于json_encode和json_decode

    json_encode将数组或者对象编码成字符串json_deode将字符串解码称对象或者数组,第二个参数为true时解码成字符串,否则解码成对象

  2. 洛谷 P1547 Out of Hay (最小生成树)

    嗯... 题目链接:https://www.luogu.org/problemnew/show/P1547 思路: 嗯...既然题中已经说了是最小生成树,那么是需要在最小生成树的模板上稍作修改即可.要 ...

  3. sysbench压力测试总结

    sysbench压力测试工具简介sysbench是一个开源的.模块化的.跨平台的多线程性能测试工具,可以用来进行CPU.内存.磁盘I/O.线程.数据库的性能测试.目前支持的数据库有MySQL.Orac ...

  4. jmeter使用BeanShell Sampler测试自己写的java接口(一)

    上次直接使用jmeter里面的FTPsampler没有连接成功 现在想着自己写java代码,通过jmeter进行调用进行连接测试实现并发 代码引文: http://www.cnblogs.com/ch ...

  5. linux 编程笔记1 crusher for linux

    1.反显示字符crusher #include <stdio.h> int main (int argc, char *argv[]) { printf("\033[7m mor ...

  6. (转)Linux下PS1、PS2、PS3、PS4使用详解

    Linux下PS1.PS2.PS3.PS4使用详解 原文:http://www.linuxidc.com/Linux/2016-10/136597.htm 1.PS1——默认提示符 如下所示,可以通过 ...

  7. Python 配置文件加载且自动更新(watchdog)

    安装依赖:pip install watchdog #!/usr/bin/env python3 # -*- coding: utf-8 -*- import logging import os im ...

  8. Oracle的表创建和事务管理

    Oracle的表创建和事务管理 - CURD,根据查询结果创建新表 - 事务管理 - 什么是事务 ,为什么要用事务 - SQL99事务隔离级别 - Oracle事务隔离级别 - 事务回滚 - 隐式回滚 ...

  9. H5移动端原生长按事件

    // 函数名longpress// 参数为: 需长按元素的id.长按之后处理函数func function longPress(id, func,timeout=500) { var timeOutE ...

  10. MySQL 返回指定长度的字符串

    今天在做 iblog 项目时,有一个需求是,从 MySQL 返回某个字段的值要时要指定长度,上网搜到的方法是使用 MySQL 的字符串处理函数,如 left(str, length),right(st ...