转自:http://zhc3191012.blog.163.com/blog/static/1855533762013823113116720/
用户任务分配办理人:
1.用户任务可以直接分配给一个用户,这可以通过humanPerformer元素定义。 humanPerformer定义需要一个 resourceAssignmentExpression
来实际定义用户
eg: <userTask id='theTask' name='important task' >
<humanPerformer>
<resourceAssignmentExpression>
<formalExpression>kermit</formalExpression>
</resourceAssignmentExpression>
</humanPerformer>
</userTask>
任务只有一个用户的时候在activiti中,用户叫做执行者。 拥有执行者的task不会出现在其他人的任务列表中, 只能出现执行者的个人任务列表中。
直接分配给用户的任务可以通过TaskService像下面这样获取:
List<Task> tasks = taskService.createTaskQuery().taskAssignee("kermit").list();
2.任务也可以加入到人员的候选人员列表中。需要使用potentialOwner元素。 用法和humanPerformer元素类似,注意它需要指定表达式中的每个
项目是人员还是群组 (引擎猜不出来)。
eg:
<userTask id='theTask' name='important task' >
<potentialOwner>
<resourceAssignmentExpression>
<formalExpression>user(kermit), group(management)</formalExpression>
</resourceAssignmentExpression>
</potentialOwner>
</userTask>
分配给候选用户列表或组的任务可以通过TaskService像下面这样获取:
List<Task> tasks = taskService.createTaskQuery().taskCandidateUser("kermit").list();
//List<Task> tasks = taskService.createTaskQuery().taskCandidateGroup("kermit").list();
此时对应办理人必须拾取任务,方能办理成功,任务被其中一个人拾取后,其他人不可见此任务
任务拾取方法: processEngine.getTaskService().claim(taskId, userId);
ps: 如果没有显示指定设置的是用户还是群组, 引擎会默认当做群组处理。所以下面的设置与使用group(accountancy)效果一样。
<formalExpression>accountancy</formalExpression>
3.Activiti对任务分配的扩展
当分配不复杂时,用户和组的设置非常麻烦。 为避免复杂性,可以使用用户任务的自定义扩展。
assignee属性:这个自定义扩展可以直接把用户任务分配给指定用户。
<userTask id="theTask" name="my task" activiti:assignee="kermit" />
它和使用上面定义的humanPerformer 效果完全一样。
candidateUsers属性:这个自定义扩展可以为任务设置候选人。
<userTask id="theTask" name="my task" activiti:candidateUsers="kermit, gonzo" />
它和使用上面定义的potentialOwner 效果完全一样。 注意它不需要像使用potentialOwner通过user(kermit)声明, 因为这个属性只能用于人员。
candidateGroups属性:这个自定义扩展可以为任务设置候选组。
<userTask id="theTask" name="my task" activiti:candidateGroups="management, accountancy" />
ps:这三个属性都可以通过流程变量动态指定值,多值需要用逗号隔开
4. 如果上面的方式还不满足需求,还可以使用创建事件的任务监听器 来实现自定义的分配逻辑:
<userTask id="task1" name="My task" >
<extensionElements>
<activiti:taskListener event="create" class="org.activiti.MyAssignmentHandler" />
</extensionElements>
</userTask>
DelegateTask会传递给TaskListener的实现, 通过它可以设置执行人,候选人和候选组:
public class MyAssignmentHandler implements TaskListener {
public void notify(DelegateTask delegateTask) {
// Execute custom identity lookups here
// and then for example call following methods:
delegateTask.setAssignee("kermit");
delegateTask.addCandidateUser("fozzie");
delegateTask.addCandidateGroup("management");
...
}
}
5. 使用spring时,可以使用表达式 把任务监听器设置为spring代理的bean, 让这个监听器监听任务的创建事件。
下面的例子中,执行者会通过调用ldapService这个spring bean的findManagerOfEmployee方法获得。
流程变量emp会作为参数传递给bean。
<userTask id="task" name="My Task" activiti:assignee="${ldapService.findManagerForEmployee(emp)}"/>
也可以用来设置候选人和候选组:
<userTask id="task" name="My Task" activiti:candidateUsers="${ldapService.findAllSales()}"/>
ps:注意方法返回类型只能为String或Collection<String> (对应候选人和候选组):
public class FakeLdapService {
public String findManagerForEmployee(String employee) {
return "Kermit The Frog";
}
public List<String> findAllSales() {
return Arrays.asList("kermit", "gonzo", "fozzie");
}
}
相关推荐
Activiti 学习笔记12:个人任务
在原有Activiti的教程资源上对零散的源码进行了集中整理,并增加了pdm、IDE集成Activiti插件等文件,附上部分菜单,整理不易,给分支持,后期...多用户任务分配 3.内置用户组设计表以及IdentityService 4.组任务分配
5. 角色管理:角色菜单权限分配、设置角色按机构进行数据范围权限划分。 6. 字典管理:对系统中经常使用的一些较为固定的数据进行维护。 7. 参数管理:对系统动态配置常用参数。 8. 通知公告:系统通知公告信息...
Activiti5用户指南(中文版) 第一章、简介 ....................................................................................................................................................................
可以把任务分配给指定的用户,也可以分配给指定的组,并且可以有多个,详见用户手册。 3.3. Spring配置文件 这里配置了数据源、事务管理、流程引擎及几个必要的xxxService。这里数据源使用的是dbcp。数据库信息就...
1. 用户管理:用户是系统操作者,该功能主要完成系统用户配置。 2. 部门管理:配置系统组织机构(公司、部门、小组),树结构展现支持数据权限。 3. 岗位管理:配置系统用户所属担任职务。 4. 菜单管理:配置系统...
用户任务的流程图,使用activiti 画出的bpmn流程图!!!!
系统管理:菜单管理、用户管理、角色管理 统一查询 pagehelper分页,配合xml编写,即可自定义查询。 采用shiro技术,可配置化权限管理 登录次数校验,超出定义次数后冻结一段时间账号 系统监控:系统日志、接口api、...
个人任务分配、组任务分配、工作流提供的用户角色组、项目框架搭建
基于Spring Boo,Security,MyBatis,Thymelea,Activiti 快速开发平台。用户是系统操作者,该功能主要完成系统用户配置。配置系统菜单,操作权限,按钮权限标识等。角色菜单权限分配、设置角色按机构进行数据范围...
定时任务:在线(添加、修改、删除)任务调度包含执行结果日志。 代码生成:前后端代码的生成(java、html、xml、sql)支持CRUD下载 。 系统接口:根据业务代码自动生成相关的api接口文档。 服务监控:监视当前系统...
工作流引擎:Activiti5 ORM框架:Mybatis Web框架:SpringMVC 核心框架:SpringBoot 任务调度:Spring Task(待定) 权限安全:Apache Shiro、Spring Security 全文搜索引擎:Lucene(待定) 模板引擎:JSP(还没使用...
工作流使用 Activiti ,支持动态表单、在线设计流程、多种任务分配方式。 高效率开发,使用代码生成器可以一键生成前后端代码 + 单元测试 + Swagger 接口文档 + Validator 参数校验。 集成微信小程序、微信公众号、...
│ 1-用户管理模块-分配角色-联动效果4 V. p8 F5 G+ n+ Q$ B │ 2-用户管理模块-分配角色-显示真实数据, H7 G# Q1 ^: [6 O │ 3-用户管理模块-分配角色-功能实现 │ 4-RBAC权限模块- │ 5-数据库表之间关系 │ 6-类...
Pear Admin Boot 开 箱 即 用 的 Spring 快 速 开 发 平 ...用户管理:用户是系统操作者,该功能主要完成系统用户配置。 权限管理:配置系统菜单,操作权限,按钮权限标识等。 角色管理:角色菜单权限分配、设置角色按
建议Star watch一份模块划分功能名称实现方式完成度功能名称实现方式完成度核心框架Sprint Boot已完成连接文档昂首阔步已完成权限管理Spring安全已完成定时任务石英已完成流程控制Activiti已完成代码生成MyBatis加号...
5、系统监控:系统日志、接口api、系统监控、可配置定时任务 6、前端可配置化定时任务。 7、采用swagger可视化出实时方法格式以及数据属性,采用阿里druid监控sql。 8、工作流程管理:完全实现模块化,无侵入。监听...
用来计算 MD5、SHA 哈希算法的 Java 类库,支持 "MD5", "SHA", "SHA-1", "SHA-256", "SHA-384", "SHA-512". 高性能RPC框架 nfs-rpc nfs-rpc是一个集成了各种知名通信框架的高性能RPC框架,目前其最好的性能为在采用...