Activiti中提供了多实例任务(for-each)将多实例应到到UserTask中可以实现会签功能。
一多实例用户任务的XML表示:
Xml代码
<userTask id="task" name="多实例任务">
<multiInstanceLoopCharacteristics isSequential="false">
<loopDataInputRef>assigneeList</loopDataInputRef>
<inputDataItem name="assignee"></inputDataItem>
<!-- userIdList[user1,user2,user3] -->
<completionCondition>${nrOfCompletedInstances/nrOfInstances >= 06}</completionCondition>
</multiInstanceLoopCharacteristics>
</userTask>
<userTask id="task" name="多实例任务">
<multiInstanceLoopCharacteristics isSequential="false">
<loopDataInputRef>assigneeList</loopDataInputRef>
<inputDataItem name="assignee"></inputDataItem>
<!-- userIdList[user1,user2,user3] -->
<completionCondition>${nrOfCompletedInstances/nrOfInstances >= 06}</completionCondition>
</multiInstanceLoopCharacteristics>
</userTask>
在每个多实例创建后都会有3个变量
nrOfInstances 实例总数
nrOfActiveInstances 当前还没有完成的实例
nrOfCompleteInstances 已经完成的实例个数
multiInstanceLoopCharacteristics 是用了指定用户任务为多实例任务,isSequential
指定多实例是按照并行或者串行的方式进行,如果使用串行方式nrOfActiveInstances 变量始终是1
loopDataInputRef
指定一个流程变量的引用,该变量是一个List,可以在发起或这执行任务之前作为流程变量放到引擎中,该list中的每一个元素将创建一个任务。元素的值通过
inputDataItem 元素的指定的变量来获取
如 在这个实例中 assigneeList =
ArraysasList("liyagn","cooperay","other"); 这会创建3个用户任务,每个用户任务中都有一个 assignee
的变量,来分别得到list中的值。
completionCondition 结束任务的条件,该示例中是任务完成 60% 结束
二给用户任务指定代理人
xml表示:
Xml代码
<userTask id="thisTask2" name="myTask2">
<humanPerformer>
<resourceAssignmentExpression>
<formalExpression>liyang</formalExpression>
</resourceAssignmentExpression>
</humanPerformer>
</userTask>
<userTask id="thisTask2" name="myTask2">
<humanPerformer>
<resourceAssignmentExpression>
<formalExpression>liyang</formalExpression>
</resourceAssignmentExpression>
</humanPerformer>
</userTask>
上面的描述将该用户任务分配给用户 liyang 可以通过
taskServicecreateTaskQuerytaskAssignee("liyang")list();来获取该任务
三通过上面两部 将 用户任务做成了多任务,也可以将 任务分配给指定的代理人,现在只用将上面两个步骤进行结合
在第一步中我们知道变量 assignee 是 会签人员的标识,只需要将指定代理人的地方用表达式来指定 assignee 变量就行了
完整XML:
Xml代码
<userTask id="thisTask2" name="myTask2">
<humanPerformer>
<resourceAssignmentExpression>
<formalExpression>${assignee}</formalExpression>
</resourceAssignmentExpression>
</humanPerformer>
<multiInstanceLoopCharacteristics isSequential="false">
<loopDataInputRef>assigneeList</loopDataInputRef>
<inputDataItem name="assignee"></inputDataItem>
<!-- userIdList[user1,user2,user3] -->
<completionCondition>${nrOfCompletedInstances/nrOfInstances >= 06}</completionCondition>
</multiInstanceLoopCharacteristics>
</userTask><SPAN style="WHITE-SPACE: pre"> </SPAN>
<userTask id="thisTask2" name="myTask2">
<humanPerformer>
<resourceAssignmentExpression>
<formalExpression>${assignee}</formalExpression>
</resourceAssignmentExpression>
</humanPerformer>
<multiInstanceLoopCharacteristics isSequential="false">
<loopDataInputRef>assigneeList</loopDataInputRef>
<inputDataItem name="assignee"></inputDataItem>
<!-- userIdList[user1,user2,user3] -->
<completionCondition>${nrOfCompletedInstances/nrOfInstances >= 06}</completionCondition>
</multiInstanceLoopCharacteristics>
</userTask>
完工。
Activiti中提供了多实例任务(for-each)将多实例应到到UserTask中可以实现会签功能。一多实例用户任务的XML表示:Xml代码assigneeList${nrOfCompletedInstances/nrOfInstances>=06}assigneeList${nrOfCompletedInstances/nrOfInstances>=06}在每个多实例创建后都会有3个变量nrOfInstances实例总数nrOfActiveInstances当前还没有完成的实例nrOfCompleteInstances已经完成的实例个数multiInstanceLoopCharacteristics是用了指定用户任务为多实例任务,isSequential指定多实例是按照并行或者串行的方式进行,如果使用串行方式nrOfActiveInstances变量始终是1loopDataInputRef指定一个流程变量的引用,该变量是一个List,可以在发起或这执行任务之前作为流程变量放到引擎中,该list中的每一个元素将创建一个任务。元素的值通过inputDataItem元素的指定的变量来获取如在这个实例中assigneeList=ArraysasList("liyagn","cooperay","other");这会创建3个用户任务,每个用户任务中都有一个assignee的变量,来分别得到list中的值。completionCondition结束任务的条件,该示例中是任务完成60%结束二给用户任务指定代理人xml表示:Xml代码liyangliyang上面的描述将该用户任务分配给用户liyang可以通过taskServicecreateTaskQuerytaskAssignee("liyang")list();来获取该任务三通过上面两部将用户任务做成了多任务,也可以将任务分配给指定的代理人,现在只用将上面两个步骤进行结合在第一步中我们知道变量assignee是会签人员的标识,只需要将指定代理人的地方用表达式来指定assignee变量就行了完整XML:Xml代码${assignee}assigneeList${nrOfCompletedInstances/nrOfInstances>=06}${assignee}assigneeList${nrOfCompletedInstances/nrOfInstances>=06}完工。
流程节点上别指定具体人,使用${userId}变量的方式。
在上一节点的添加TaskListener,完成事件,对userId进行设置。
public class AssigneeSearch2 implements TaskListener {
public void notify(DelegateTask delegateTask) {
String userId = delegateTaskgetVariable("applyUserId")toString();
if ("user01"equalsIgnoreCase(userId) ) {
delegateTasksetVariable("userId", "leaderuser");
}
}
}
}
createTaskQuery()、首先是根据流程ID获取当前任务: ProcessDefinitionEntity def = (P,然后根据流程定义获得所有的节点list(); 2processInstanceId(procInstanceId)1、然后根据当前任务获取当前流程的流程定义: List tasks = taskService
1BPMN 20模式的根元素是definitions元素。
多实例相关属性,以eclipse中的可视化图形 *** 作为例
Multil instance:
Sequential:执行顺序。必选项,可选值有true、false。用于设置多实例的执行顺序。True:多实例顺序执行,false:多实例并行
loop cardinality:循环基数。可选项。可以直接填整数,表示会签的人数。
Collection:集合。可选项。会签人数的集合,通常为list。和loop cardinality二选一
Element variable:元素变量。选择Collection时必选,为collection集合每次遍历的元素
Completion condition:完成条件。可选。Activiti会签有个特性,比如设置一个人完成后会签结束,那么其他人的代办任务都会消失。
>
您好,很高兴为您解答,可通过taskService方法:taskService:ListgetIdentityLinksForTask(StringtaskId)如:for(IdentityLinkil:taskServicegetIdentityLinksForTask(taskId))希望对你有用,望采纳。
在查询流程实例时,通过 businessKey(业务标识 )关联查询业务系统的请假单表,查询出请假天
数等信息。
*** 作流程定义为挂起状态,该流程定义下边所有的流程实例全部暂停:
流程定义为挂起状态该流程定义将不允许启动新的流程实例,同时该流程定义下所有的流程实例将
全部挂起暂停执行。
*** 作流程实例对象,针对单个流程执行挂起 *** 作,某个流程实例挂起则此流程不再继续执行,完成
该流程实例的当前任务将报异常。
讲bpmn流程文件中节点的assignee 使用UEL表达式赋值( ${assignee0} )
任务监听器是发生对应的任务相关事件时执行自定义 java 逻辑 或表达式。
Create:任务创建后触发
Assignment:任务分配后触发
Delete:任务完成后触发
All:所有事件发生都触发
定义任务监听类,且类必须实现 orgactivitienginedelegateTaskListener 接口
在部门经理审核前设置流程变量,变量值为请假单信息(包括请假天数),部门经理审核后可以根据
流程变量的值决定流程走向。
通过流程实例 id 设置全局变量,该流程实例必须未执行完成。
任务办理时设置 local 流程变量,当前运行的流程实例只能在该任务结束前使用,任务结束该变量无
法在当前流程实例使用,可以通过查询历史任务查询。
注意:
任务 id 必须是当前待办任务 id,act_ru_task 中存在。
当前版本为activiti60,与之前版本区别
assignee:任务执行人,设置系统中的“登录名”(loginName)。
candidateUsers:任务执行人,可以填写多个。
candidateGroups:任务执行组,可以填写多个,设置系统中的“角色英文名(enname)”。
assignee和candidateUsers的区别是:assignee不需要签收任务,直接可执行任务;candidateUsers为竞争方式分配任务,被指定人待办中都有一条任务,谁先签收谁就获得任务的执行权。
taskServicesetAssignee(String taskId, String userId);
taskServiceclaim(String taskId, String userId);
taskServicesetOwner(String taskId, String userId);
关于上面三个方法的区别:
setAssignee和claim两个的区别是在认领任务时,claim会检查该任务是否已经被认领,如果被认领则会抛出ActivitiTaskAlreadyClaimedException 而setAssignee不会进行这样的检查。其他方面两个方法效果一致。
setOwner和setAssignee的区别在于
setOwner实在代理任务时使用,代表着任务的归属者,而这时,setAssignee代表的时代理办理者,
举个例子来说,公司总经理现在有个任务taskA,去核实一下本年度的财务报表,他现在又很忙没时间,于是将该任务委托给其助理进行办理,此时,就应该这么做:
taskServicesetOwner(taskAgetId(), 总经理getId());
taskServicesetAssignee/claim(taskAgetId(), 助理getId());
act_hi_taskinst表两个字段:
DELEGATION_和OWENER_
DELEGATION_值变化为PENDING,表示此任务为正在执行的委托任务;
DELEGATION_值变化为 RESOLVED,表示此任务为被解决的委托任务;
所以任务在被委托人执行时必须
taskServiceresolveTask(taskgetId(),taskVariables);//解决委托
taskServicecomplete(taskgetId(), taskVariables);//完成任务
否则容易报错A delegated task cannot be completed, but should be resolved instead
OWENR_字段设置用于查询委任人的委托任务
在执行taskServiceaddComment前,需要设置批注的所属人AuthenticationsetAuthenticatedUserId(userId);
在流程启动实例之前,设置启动者identityServicesetAuthenticatedUserId(userId);
然后流程设计模型可在流程开始节点设置变量,以供之后的环节使用
级联删除会把流程实例流程历史全部物理清空。
非级联删除,必须保证没有流程实例
二者虽然都能查询到任务实例。但是前者只能查询历史环节,就算act_hi_taskinst有数据未完成当前环节也不能查出
以上就是关于activiti工作流怎样定时启动工作流全部的内容,包括:activiti工作流怎样定时启动工作流、工作流activiti 怎么实现会签、activiti已经获得了UserTask节点,但是我设置的是变量,怎么获得值信息。或者activiti怎么获得全部审批人等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)