activiti工作流引擎学习(三)
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工作流引擎学习(三)的更多相关文章
- Activiti工作流引擎学习(一)
1.部署对象和流程定义相关表:RepositoryService act_re_deployment: 部署对象表:一次部署的多个文件的信息,对于不需要的流程可以删除和修改 act_re_procde ...
- activiti工作流引擎学习(二)
1.连线 如果bpmn文件和java文件放在同一目录下,需要配置buildPath: 使用流程变量,设置连线需要的流程变量的名称,并设置流程变量的值,流程会按照指定的连线完成任务. 1.1一个活动中可 ...
- Activiti工作流引擎开发系列
Activiti工作流引擎开发系列-01 作者:Jesai 没有伞的孩子,只能光脚奔跑! 前言: 初次接触工作流这个概念是自从2014年11月份开始,当时是由于我的毕业设计需要,还记得当时我毕业设计的 ...
- Activiti工作流引擎简介
Activiti工作流引擎简介 一.概述 Activiti是由Alfresco软件在2010年5月17日发布的业务流程管理(BPM)框架,它是覆盖了业务流程管理,工作流,服务协作等领域的一个开源,灵活 ...
- Activiti工作流引擎数据库表结构
Activiti工作流引擎数据库表结构 一.数据库表的命名 Acitiviti数据库中表的命名都是以ACT_开头的.第二部分是一个两个字符用例表的标识.此用例大体与服务API是匹配的. ACT_RE_ ...
- Activiti工作流框架学习(一)之通用数据表详细介绍
文/朱季谦 Activiti工作流引擎自带了一套数据库表,这里面有一个需要注意的地方: 低于5.6.4的MySQL版本不支持时间戳或毫秒级的日期.更糟糕的是,某些版本在尝试创建此类列时将引发异常,而其 ...
- Activiti工作流引擎参考资料
Activiti工作流引擎使用 工作流-Activiti核心API介绍 传智播客Activiti工作流视频教程(企业开发实例讲解) 工作流引擎Activiti演示项目 http://www.kafei ...
- Activiti工作流框架学习笔记(二)之springboot2.0整合工作流Activiti6.0
以前在工作当中做过不少与工作流Activiti有关的工作,当时都是spring集成activiti5.22的项目,现在回过头去看,其实版本已经稍微老了,因此,基于先前的工作经验,决定用较新版本的技术来 ...
- activiti工作流引擎
参考文章 Activiti-5.18.0与springMvc项目集成和activiti-explorer单独部署Web项目并与业务数据库关联方法(AutoEE_V2实现方式) https://blog ...
随机推荐
- Python 基于 NLP 的文本分类
这是前一段时间在做的事情,有些python库需要python3.5以上,所以mac请先升级 brew安装以下就好,然后Preference(comm+',')->Project: Text-Cl ...
- Directx11教程(16) D3D11管线(5)
原文:Directx11教程(16) D3D11管线(5) 本章我们学习VS中具体做些什么事情? 首先再看看我们的VS shader代码: Clolor.vs - PixelInputType Col ...
- QT UI 线程为什么卡死?
我的工程是由三个线程处理不同任务构成的,其中UI用于显示,还有数据处理和数据接收发送线程. 在运行的过程中发现由于数据处理线程不及时,超过了设定的100ms,导致UI卡死,几个周期后又恢复,接着又卡死 ...
- Effective Modern C++:02auto
05:优先使用auto,而非显示类型声明 显示类型声明有下面一些缺点: int x; //未初始化,或者初始化为0,视语境而定 template<typename It> void dwi ...
- Person Re-identification 系列论文笔记(一):Scalable Person Re-identification: A Benchmark
打算整理一个关于Person Re-identification的系列论文笔记,主要记录近年CNN快速发展中的部分有亮点和借鉴意义的论文. 论文笔记流程采用contributions->algo ...
- HZOJ Dash Speed
测试点1-2:暴力. 测试点3-4:可以将边按r从大到小排序不断加入,然后用并茶几维护深度.好像也可以用猫树做. 好吧其他的部分分并没有看懂. 正解: 线段树分治,求出每个速度的答案. 对于速度区间$ ...
- ArcMap影像纠偏
客户给了一张PNG图,如下图,需要提取其中北极航线. 策略是ArcMap中先配准PNG,使之与底图较好重合.再新建线图层,描出航线.这种彩色丰富的图,很难用栅格转矢量的方式,故应用描边法. 一.配准P ...
- React Native等比放大不丢失图片
9月11号 0.33版本,resizeMode中添加了center, 可以实现一样的功能.不过希望这篇文章还能帮助大家. 之前我们学习了从零学React Native之08Image组件 大家可以发现 ...
- oralce CUBE
select id,area,stu_type,sum(score) score from students group by cube(id,area,stu_type) order by id,a ...
- Java练习 SDUT-1194_余弦
C语言实验--余弦 Time Limit: 1000 ms Memory Limit: 65536 KiB Problem Description 输入n的值,计算cos(x). Input 输入数据 ...