activiti工作流怎样定时启动工作流

activiti工作流怎样定时启动工作流,第1张

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怎么获得全部审批人等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/10147410.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-05
下一篇 2023-05-05

发表评论

登录后才能评论

评论列表(0条)

保存