5、接收任务活动(receiveTask,即等待活动)不是一个任务节点
接收任务是一个简单任务,他会等待回应消息的到达,当前,官方只实现了这个任务的java语义,当流程达到接受任务,流程状态会保存到数据库中;
在任务创建后,意味着流程会进入等待状态,知道引擎接收了一个特定的消息,这会触发流程穿过接收任务继续执行;

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

6、个人任务(userTask,即用户操作的任务)Assignee
6.1、之前的做法是直接把办理人放在了xml中,不够灵活
6.2、分配个人任务方式二(使用流程变量)
6.3、分配个人任务方式三(使用类动态指定,实现TaskListener接口)
6.4、分配个人任务从一个人指定到另一个人(任务认领,比如这个人请假了,可以指派给另一个人处理)

/**
* 启动流程实例,使用流程变量指定审批人
* @return
*/
@RequestMapping("sequence/starttaskOne")
public String startSequenceFlow(){ String processDefinitionKey = "taskOne"; Map<String, Object> map = new HashMap<String, Object>();
map.put("userId", "xxx"); //正在执行的流程实例和执行对象相关的service
RuntimeService runtimeService = processEngine.getRuntimeService(); //使用流程定义的key启动流程实例,key对应的是bpmn文件中的id,默认是最新版本的流程启动
ProcessInstance processInstance = runtimeService.startProcessInstanceByKey(processDefinitionKey,map); System.out.println(processInstance.getId() + processInstance.getProcessDefinitionId()); return processInstance.getProcessDefinitionId();
}

7、组任务分配 Condidate users

act_ru_identitylink : 任务办理人表(个人任务,组任务);个人任务会有一条数据,组任务会有两条数据,type不一样(参与者,候选者)
act_ru_identitylink : 历史任务办理人表(个人任务,组任务)

7.1、拾取组任务分配为个人任务,指定任务人员可以是非组内成员
还可以将个人任务回退为组任务,前提之前必须是一个组任务,将assignee设置为null即可

7.2、向组任务中添加成员 / 删除成员

7.3、分配任务的三种方式: 写在xml中、使用流程变量、使用类

package com.controller;
/**
*使用类分配任务
*/
import org.activiti.engine.delegate.DelegateTask;
import org.activiti.engine.delegate.TaskListener; public class TaskListenerImpl implements TaskListener { @Override
public void notify(DelegateTask task) {
//设置个人任务
//task.setAssignee(""); //设置组任务
task.addCandidateUser("小A");
task.addCandidateUser("小B");
task.addCandidateUser("小C"); } }

  

/**
* 查询当前人的个人任务
* @return
*/
@RequestMapping("sequence/findGroupOne")
public String findGateWayTask(){ String assignee = "daF"; List<Task> list = processEngine.getTaskService()
.createTaskQuery()
.taskAssignee(assignee).list(); if(!CollectionUtils.isEmpty(list)){
for (Task task : list) {
System.out.println(task.getAssignee());
System.out.println(task.getId());
System.out.println(task.getName());
System.out.println(task.getExecutionId());
}
} System.out.println("****************"); return list.toString();
} /**
* 查询正在执行的的任务办理人表
*/
@GetMapping("group/findP")
public String findPersonal(){ String taskId = "57509"; List<IdentityLink> links = processEngine.getTaskService()
.getIdentityLinksForTask(taskId); for (int i = 0; i < links.size(); i++) {
System.err.println(links.get(i).getUserId());
} return String.valueOf(links.size());
}
/**
* 查询历史任务办理人表
*/
@GetMapping("group/findHisP")
public String findHisPersonal(){ String taskId = "57509"; List<HistoricIdentityLink> links = processEngine.getHistoryService()
.getHistoricIdentityLinksForTask(taskId); for (int i = 0; i < links.size(); i++) {
System.err.println(links.get(i).getUserId());
} return String.valueOf(links.size());
} /**
* 拾取任务,将组任务分给个人任务,指定任务的办理人
* @return
*/
@GetMapping("group/claim")
public String claim(){ String taskId = "57509";
String userId = "daF"; processEngine.getTaskService()
.claim(taskId, userId); return "success!";
} /**
* 将个人任务回退回组任务
* @return
*/
@GetMapping("group/returnClaim")
public String returnClaim(){ String taskId = "57509"; processEngine.getTaskService()
.claim(taskId, null); return "success!";
} /**
* 向组任务中添加人
* @return
*/
@GetMapping("group/addUser")
public String addGroupUser(){ String taskId = "57509"; processEngine.getTaskService()
.addCandidateUser(taskId, "大s"); return "success!";
} /**
* 向组任务添删除人
* @return
*/
@GetMapping("group/delUser")
public String delGroupUser(){ String taskId = "57509"; String userId = "大s"; processEngine.getTaskService()
.deleteCandidateUser(taskId, userId); return "success!";
}

  

7.4、工作流定义的角色组 IdentityService(组织机构管理)

act_id_group: 角色表
act_id_user :用户表
act_id_membership :用户角色关系表

/**
* 部署
* @return
*/
@GetMapping("sequence/deployCandidateGroup")
public String deploySequenceFlow(){ InputStream bpmn = this.getClass().getResourceAsStream("/diagrams/cadinerGroup.bpmn");
InputStream png = this.getClass().getResourceAsStream("/diagrams/cadinerGroup.png"); Deployment deployment = processEngine.getRepositoryService().createDeployment().name("组任务")
.addInputStream("cadinerGroup.bpmn", bpmn)//与资源文件名称要一致
.addInputStream("cadinerGroup.png", png)
.deploy(); System.err.println(deployment.getKey() + "---" + deployment.getName()); //添加用户角色组
IdentityService identityService = processEngine.getIdentityService(); //创建角色
//identityService.saveGroup(Group);; //创建用户
//identityService.saveUser(user); //创建角色用户的关联关系
//identityService.createMembership(userId, groupId); System.out.println("添加组织机构成功!"); return deployment.getId();
}

  

activiti工作流引擎学习(三)的更多相关文章

  1. Activiti工作流引擎学习(一)

    1.部署对象和流程定义相关表:RepositoryService act_re_deployment: 部署对象表:一次部署的多个文件的信息,对于不需要的流程可以删除和修改 act_re_procde ...

  2. activiti工作流引擎学习(二)

    1.连线 如果bpmn文件和java文件放在同一目录下,需要配置buildPath: 使用流程变量,设置连线需要的流程变量的名称,并设置流程变量的值,流程会按照指定的连线完成任务. 1.1一个活动中可 ...

  3. Activiti工作流引擎开发系列

    Activiti工作流引擎开发系列-01 作者:Jesai 没有伞的孩子,只能光脚奔跑! 前言: 初次接触工作流这个概念是自从2014年11月份开始,当时是由于我的毕业设计需要,还记得当时我毕业设计的 ...

  4. Activiti工作流引擎简介

    Activiti工作流引擎简介 一.概述 Activiti是由Alfresco软件在2010年5月17日发布的业务流程管理(BPM)框架,它是覆盖了业务流程管理,工作流,服务协作等领域的一个开源,灵活 ...

  5. Activiti工作流引擎数据库表结构

    Activiti工作流引擎数据库表结构 一.数据库表的命名 Acitiviti数据库中表的命名都是以ACT_开头的.第二部分是一个两个字符用例表的标识.此用例大体与服务API是匹配的. ACT_RE_ ...

  6. Activiti工作流框架学习(一)之通用数据表详细介绍

    文/朱季谦 Activiti工作流引擎自带了一套数据库表,这里面有一个需要注意的地方: 低于5.6.4的MySQL版本不支持时间戳或毫秒级的日期.更糟糕的是,某些版本在尝试创建此类列时将引发异常,而其 ...

  7. Activiti工作流引擎参考资料

    Activiti工作流引擎使用 工作流-Activiti核心API介绍 传智播客Activiti工作流视频教程(企业开发实例讲解) 工作流引擎Activiti演示项目 http://www.kafei ...

  8. Activiti工作流框架学习笔记(二)之springboot2.0整合工作流Activiti6.0

    以前在工作当中做过不少与工作流Activiti有关的工作,当时都是spring集成activiti5.22的项目,现在回过头去看,其实版本已经稍微老了,因此,基于先前的工作经验,决定用较新版本的技术来 ...

  9. activiti工作流引擎

    参考文章 Activiti-5.18.0与springMvc项目集成和activiti-explorer单独部署Web项目并与业务数据库关联方法(AutoEE_V2实现方式) https://blog ...

随机推荐

  1. Directx教程(23) 简单的光照模型(2)

    原文:Directx教程(23) 简单的光照模型(2)    在工程myTutorialD3D11_16中,我在文件light.vs中定义了一个材质光源属性常量缓冲. //const buffer最好 ...

  2. UVA_10300:Ecological Premium

    Sample Input 351 1 12 2 23 3 32 3 48 9 239 1 86 12 18 1 1310 30 409 8 5100 1000 70Sample Output 3886 ...

  3. Linus 本尊也来了!为什么 KubeCon 越来越火了?

    2015年11月,第一届 KubeCon 在美国旧金山开始的时候,还只是个200人的小会议,2019年的7月,KubeCon 第二次在中国举办,就有 3500 多位云原生和开源领域工程师齐聚一堂. 连 ...

  4. MUI - 关于百度定位

    关于百度定位 这是官方定位的解释:geolocation 地图插件配置 我在问答里面找到了这位童鞋的百度定位,地址变更提醒 *** 不过,童鞋倒是给具体的示例啊,木有~~~~(>_<)~~ ...

  5. H5本地存储技术和微信小程序中的本地存储

    1.H5的本地存储 <!DOCTYPE html> <html lang="en"> <head> <meta charset=" ...

  6. MySql计算两日期时间之间相差的天数,秒数,分钟数,周数,小时数

    MySql计算两日期时间之间相差的天数,秒数,分钟数,周数,小时数 计算两日期时间之间相差的天数,秒数,分钟数,周数,小时数,这里主要分享的是通过MySql内置的函数 TimeStampDiff() ...

  7. WPF 线段Line过长渲染出现的问题

    原文:WPF 线段Line过长渲染出现的问题 在使用WPF的时候,可以做一个实验,在canvas里添加一条线段Line,StrokeThickness属性设置为1,然后通过放大canvas或者调整li ...

  8. Java练习 SDUT-1188_各位数字之和排序

    C语言实验--各位数字之和排序 Time Limit: 1000 ms Memory Limit: 65536 KiB Problem Description 给定n个正整数,根据各位数字之和从小到大 ...

  9. Redis源码解析:05跳跃表

    一:基本概念 跳跃表是一种随机化的数据结构,在查找.插入和删除这些字典操作上,其效率可比拟于平衡二叉树(如红黑树),大多数操作只需要O(log n)平均时间,但它的代码以及原理更简单.跳跃表的定义如下 ...

  10. @codeforces - 414E@ Mashmokh's Designed Problem

    目录 @description@ @solution@ @accepted code@ @details@ @description@ 给定一棵 n 个点的树,每个点的儿子是有序的. 现给定 m 次操 ...