`
上杉t
  • 浏览: 32550 次
文章分类
社区版块
存档分类
最新评论

一个JBPM实现互斥撤回任务的例子

阅读更多
        有一个需求是这个样子的:员工请假,填写好请假单后,提交申请.上级主管会有一个审核请假的任务,同时申请人有一个撤回的任务.这这两个任务互斥,也就是说两个任务有一个先执行.另一个任务取消.
       曾经看过网上一篇文章使用分支节点创建两个任务节点.当一个任务节点执行后写一个action类负责结束另一个任务节点.达到互斥撤回的效果.本人试验过确实可以完成.
       不过这不符合我们常规的流程定义方式(需要增加一对分支,联合节点).并且不符合jbpm关于节点描述.
       jbpm认为一个节点代表流程中的一个等待状态.显然领导审核和员工撤销请假处于同一个等待状态,也应该处于一个节点中.使用一对分支,联合节点的方式虽然形式上处于一个等待状态.但这样的流程设计是不合适的.
       可以这样设计这个互斥回撤节点

<task-node name="审核" signal="first" end-tasks="true"><task name="审核员工请假" swimlane="boss" template="apply_2.ftl"><controller><variable name="reason" access="read" mapped-name="reason"><variable name="day" access="read,write" mapped-name="day"><variable name="applyman" access="read" mapped-name="applyman"> </variable></variable></variable></controller></task></task-node>
xml 代码
 
  1. <task-node name="审核" signal="first" end-tasks="true">  
  2.         <task name="审核员工请假" swimlane="boss" template="apply_2.ftl">  
  3.     <controller>  
  4.           <variable name="reason" access="read" mapped-name="reason"/>  
  5.          <variable name="day" access="read,write" mapped-name="day"/>  
  6.          <variable name="applyman" access="read" mapped-name="applyman"/>  
  7.          <variable name="decision" access="read,write" mapped-name="decision"/>  
  8.        <!---->controller>   
  9.    <!---->task>  
  10.     <task name="撤回请假单" swimlane="applyman" template="apply_3_new.ftl">  
  11.     <controller>  
  12.           <variable name="reason" access="read" mapped-name="reason"/>  
  13.          <variable name="day" access="read" mapped-name="day"/>  
  14.          <variable name="applyman" access="read" mapped-name="applyman"/>  
  15.          <variable name="decision" access="read,write" mapped-name="decision"/>  
  16.        <!---->controller>  
  17.    <!---->task>  
  18.     
  19.      <transition name="结束" to="归档"><!---->transition>  
  20.      <transition name="撤销" to="请假结束"><!---->transition>  
  21.      <transition name="修改" to="修改"><!---->transition>  
  22.   <!---->task-node>  
<task name="撤回请假单" swimlane="applyman" template="apply_3_new.ftl"><controller><variable name="reason" access="read" mapped-name="reason"><task-node name="审核"><task template="apply_2.ftl" swimlane="boss" name="审核员工请假"><controller><variable mapped-name="reason" access="read" name="reason"><variable mapped-name="day" access="read,write" name="day"><task template="apply_3_new.ftl" swimlane="applyman" name="撤回请假单"><controller><variable mapped-name="reason" access="read" name="reason"><variable mapped-name="day" access="read" name="day">

这个节点包含了我们刚才说的两个任务.我们知道当流传到这个节点的时候.这两个任务会同时创建并分配给各自的人员.有一个人完成任务后 节点向指定的节点转向.同时结束另一个任务.    signal="first" 有一个任务结束节点就流转.  end-tasks="true" 结束该节点的时候自动结束其他没有完成的任务.

       这是个小例子没什么特别.可能早有高人知晓.在这我只是感觉到jbpm对节点是流程的一个等待状态这个含义,对我们设计流程有重要的意义.欢迎大家指正批评

   完整的xml流程定义.如果你要部署这个流程.这里需要说明的是</variable></variable></controller></task></variable></variable></controller></task></task-node></variable></controller></task><variable name="reason" access="read" mapped-name="reason"><variable mapped-name="reason" access="read" name="reason"><variable mapped-name="day" access="read,write" name="day"><variable mapped-name="reason" access="read" name="reason"><variable mapped-name="day" access="read" name="day">com.jbpmexample.jbpm.Assignment类是我自己的授权类.你自己写一个代替就好了,</variable></variable></variable></variable></variable><variable name="reason" access="read" mapped-name="reason"><variable mapped-name="reason" access="read" name="reason"><variable mapped-name="day" access="read,write" name="day"><variable mapped-name="reason" access="read" name="reason"><variable mapped-name="day" access="read" name="day">template="apply_1.ftl"  这样的属性是我自己加的 为了实现显示页面的定制.需要去掉.否则部署的时候会报错</variable></variable></variable></variable></variable><task name="撤回请假单" swimlane="applyman" template="apply_3_new.ftl"><controller><variable name="reason" access="read" mapped-name="reason"><task-node name="审核"><task template="apply_2.ftl" swimlane="boss" name="审核员工请假"><controller><variable mapped-name="reason" access="read" name="reason"><variable mapped-name="day" access="read,write" name="day"><task template="apply_3_new.ftl" swimlane="applyman" name="撤回请假单"><controller><variable mapped-name="reason" access="read" name="reason"><variable mapped-name="day" access="read" name="day">
xml 代码
 
  1. <?xml version="1.0" encoding="UTF-8"?>  
  2.   
  3. <process-definition  
  4.   xmlns="urn:jbpm.org:jpdl-3.1"  name="新请假流程">  
  5.   <swimlane name="applyman" />  
  6.     
  7.   <swimlane name="boss">  
  8.     <assignment class="com.jbpmexample.jbpm.Assignment">  
  9.          <swimlaneName>boss</swimlaneName>  
  10.       </assignment>  
  11.   </swimlane>  
  12.     
  13.    <start-state name="请假开始">  
  14.     <task name="填写请假单" swimlane="applyman" <variable name="reason" access="read" mapped-name="reason"><variable mapped-name="reason" access="read" name="reason"><variable mapped-name="day" access="read,write" name="day"><variable mapped-name="reason" access="read" name="reason"><variable mapped-name="day" access="read" name="day">template="apply_1.ftl"</variable></variable></variable></variable></variable>>  
  15.         <controller>  
  16.           <variable name="reason" access="read,write" mapped-name="reason"/>  
  17.           <variable name="day" access="read,write" mapped-name="day"/>  
  18.           <variable name="applyman" access="read,write" mapped-name="applyman"/>  
  19.         </controller>   
  20.     </task>  
  21.       <transition name="结束" to="审核"></transition>  
  22.    </start-state>  
  23.    <task-node name="审核" signal="first" end-tasks="true">  
  24.         <task name="审核员工请假" swimlane="boss" template="apply_2.ftl">  
  25.         <controller>  
  26.            <variable name="reason" access="read" mapped-name="reason"/>  
  27.           <variable name="day" access="read,write" mapped-name="day"/>  
  28.           <variable name="applyman" access="read" mapped-name="applyman"/>  
  29.           <variable name="decision" access="read,write" mapped-name="decision"/>  
  30.         </controller>   
  31.     </task>  
  32.         <task name="撤回请假单" swimlane="applyman" template="apply_3_new.ftl">  
  33.         <controller>  
  34.            <variable name="reason" access="read" mapped-name="reason"/>  
  35.           <variable name="day" access="read" mapped-name="day"/>  
  36.           <variable name="applyman" access="read" mapped-name="applyman"/>  
  37.           <variable name="decision" access="read,write" mapped-name="decision"/>  
  38.         </controller>  
  39.     </task>  
  40.      
  41.       <transition name="结束" to="归档"></transition>  
  42.       <transition name="撤销" to="请假结束"></transition>  
  43.       <transition name="修改" to="修改"></transition>  
  44.    </task-node>  
  45.    <task-node name="归档">  
  46.         <task name="请假归档" swimlane="applyman" template="apply_4.ftl">  
  47.         <controller>  
  48.            <variable name="reason" access="read" mapped-name="reason"/>  
  49.           <variable name="day" access="read" mapped-name="day"/>  
  50.           <variable name="applyman" access="read" mapped-name="applyman"/>  
  51.           <variable name="decision" access="read" mapped-name="decision"/>  
  52.         </controller>   
  53.     </task>  
  54.       <transition name="结束" to="请假结束"></transition>  
  55.    </task-node>  
  56.    <end-state name="请假结束"></end-state>  
  57.      
  58.    <task-node name="修改">  
  59.    <task name="修改" swimlane="applyman" template="apply_1.ftl">  
  60.         <controller>  
  61.            <variable name="reason" access="read,write" mapped-name="reason"/>  
  62.           <variable name="day" access="read,write" mapped-name="day"/>  
  63.           <variable name="applyman" access="read" mapped-name="applyman"/>  
  64.         </controller>   
  65.     </task>  
  66.       <transition name="结束" to="审核"></transition>  
  67.    </task-node>  
  68. </process-definition>  
</variable></variable></controller></task></variable></variable></controller></task></task-node></variable></controller></task>
分享到:
评论
22 楼 finikes 2009-02-14  
如何控制使得不会员工自己批了自己的假呢?
21 楼 yuyanshan 2008-08-26  
xman 2008-06-08 
你把事情想得太简单了。
如果审核的过程需要几个步骤,如部门主管审核,综合部审核,公司主管审核。。。,还能用你这种方法吗?不是还得用fork join

我也觉得是这样,我现在就碰到这种情况了,不知道怎么做,用fork join还有问题,在join那不知道怎么设置让有一路任务完成就向下执行,请问有没有什么好方法呀
20 楼 zhoden 2008-07-28  
已写得很好了!
19 楼 pig345 2008-06-30  
佩服LZ,这个方案能完美地解决大多数情况下的撤回问题了。
另外似乎到了JBPM3.2.x,里面所带例子很少,单元测试也没有了,不知道是怎么回事?
18 楼 skyremark 2008-06-24  
  
17 楼 xman 2008-06-08  
你把事情想得太简单了。
如果审核的过程需要几个步骤,如部门主管审核,综合部审核,公司主管审核。。。,还能用你这种方法吗?不是还得用fork join
16 楼 gabriel80 2008-04-07  
看了下。。一年前的文章啊
15 楼 oisiv 2007-05-25  
嗯,看来你是善于积极动手解决自己碰到的问题。呵呵,而我很怕麻烦,要向你学习啊。

不过的确,因为我也要手动解析流程xml,得到特定任务列表(我在task-node那里用description做数字标识,可以用来排序),在它的规范下实在是无法用到xpath,不管怎么在网上找方法,都解决不了,最后只能用笨方法,在从流程库中取得xml文件後,转成string,然后用字符串替换方法,替换掉xmlns的内容。这样又可以用xpath查询了。

到目前为止,个人感觉jbpm很不成熟啊,它的javadoc很不值得称道;jpdl的扩展性不强,所有这些,让人用起来很不顺手。不过总比自己实现要来得好。

最近在处理jbpm在spring应用中的使用,网上的整合方法,有些搞不懂,总觉得不适合自己的架构,我现在就一直在解决整合jbpm後的事务问题,找不到合适的方法。
14 楼 上杉t 2007-05-25  
奥 我改了它的规范,加入了我新添的属性,然后一起打包zip来发布,流程图文件还是一个,自己写一个部署方法吧jbpm的包装一下就好。就是一个拆包的过程。jbpm自己也有一个zip部署的方式不是 ,参考了一下。它的规范可以改一下。很简单。就是它的规范不准许使用xpath语句。解析xml文件略麻烦。参考一下它的解析方法就可以了
13 楼 oisiv 2007-05-25  
现在了解了你为什么要用模板了。不过你加了这个模板属性,因为它不是规范里的属性,那如何能发布呢?

难道存在两个流程图文件,分别提供给UI使用,或是给jbpm使用
12 楼 上杉t 2007-05-25  
呵呵,虽然流程图中不能注明什么任务应该有什么转向可供选择
你可以在页面表现上写好。审核员工请假的任务有撤销,和结束两个转向,而撤回请假单有撤销一个转向。完全可以。我的流程任务是可以挂模板页面的。我想你说的那种是不需要模板页面的情况了。所有任务是一个页面了。
如果使用fork,join会很麻烦的,而且客户定制时会很不理解。我最早也这样。
11 楼 oisiv 2007-05-24  
转向是个严重问题,因为jpdl还是不很完善,所以在流程图声明文件里无法注明:什么任务应该有什么转向可供选择。

如上面的的例子中,互斥任务中的“撤销”转向,仅仅只提供给申请人使用,而"结束"和"修改" 就提供给另外的任务使用。那么在程序中将如何挑选这些不同转向给互斥任务分别使用呢。我觉得上面的流程设计就很困难了。

后来在自己的项目中,为了解决互斥问题,就采用了fork,join,将互斥任务放在不同的分支,及不同的节点上,然后在节点上放入任务对应的转向。这样在UI上,就可根据任务的id得到可到达的转向了。

采用fork,join後,又有个重要问题出现了,不同分支是互斥的,当某个分支到达join後,将继续向下执行,目地达到了。但其他分支上的任务并没有结束。所以只好在不同分支的任务上,设立node-leave事件action,触发执行一个类,主动结束其他分支上创建的任务,以及分支Token。(Token要先于任务进行结束动作,不然,当结束任务时,会继续执行到下一节点。)

10 楼 microsoftwxj 2007-04-27  
请教一下:task-node节点上怎样实现不同的转向的呢?
也就是在  task-node name="审核" 中怎么样转向不同的
transition name="结束" 
transition name="撤销"
transition name="修改"


9 楼 上杉t 2007-03-16  
看了你的留言我感觉是不是我们“动态创建Task”这个实现方式不一样.所以我在两点上和你交流一下
第一:我在做动态创建Task时(也是为了实现会签)task-node节点中只有一个任务,别且转入这个节点时不是流程创建的任务,是由node-enter事件的action类完成了创建n个相同的任务给不同的人.这个不知和你是否一样.
第二:我没有取消会签的任务(我看你的留言好像意思是有个取消会签的任务).如果需要这个任务我觉的这个任务应该单独有个事件action类.在这个类里面不但要task.end() 还要processInstance.signal("回退") 这样节点就流转了 至于其他会签任务 end-tasks="true" 在离开节点时,所有打开的任务将被结束.
    对于第二点我没有试验过.
8 楼 tomkoo 2007-03-16  

对没错,使用动态创建Task的时候是设置signal="last-wait",让所有的TaskInstance都完成了再到下一步。

但是在“会签”中,只要上一步任务一提交,会签的N个TaskInstance就已经创建,包括用来取消提交任务的TaskInstrance。这个时候,如果我们撤销提交,本来应该回到前一个节点,但是由于我们设置的是signal="last-wait",所以并不能像我们预期的一样,回到上一个节点。
7 楼 上杉t 2007-03-15  
task-node节点的默认设置是完成所有任务才流转.所以不用设置signal="first" end-tasks="true" 就不会你有担心的问题了.
signal属性可选值:
   last:这是默认值。当最后一个任务实例完成时继续执行;当在节点入口处没有任务创建时,继续执行。
   last-wait:当最后一个任务实例完成时继续执行;当在节点入口处没有任务创建时,执行在任务节点等待,直到任务被创建。
   first:当第一个任务实例完成时继续执行;当在节点入口处没有任务创建时,继续执行。
   first-wait:当第一个任务实例完成时继续执行;当在节点入口处没有任务创建时,执行在任务节点等待,直到任务被创建。
  unsynchronized:总是继续执行,不管任务是否创建和完成。
  never:执行不再继续,不管任务是否创建和完成。

其实我认为“动态创建Task”时应该设signal="last-wait" 因为这样就不会多创建一个多余的没有参与者的任务了(进入task-node会创建一个任务,但这个时候还没参与者)
6 楼 tomkoo 2007-03-15  
突然想到一个问题,就是当我们流程中有“会签”的时候,而且这个会签是基于“动态创建Task”来实现的,这个时候需要完成所有的TaskInstance才能流转到下一个节点。这个时候这个实现方法似乎有点问题。可能要变通一下才可以行得通。
5 楼 tomkoo 2007-03-15  
上杉t 老兄,这个思路真的很好!     ;我也在这个问题上思考了很久的时间,后来基本上也是适用前一种方法来实现,感觉就是一个字“不爽”(好像是两个字 ),流程很复杂!今天看到你这个帖子才茅舍顿开。哈哈。好铁,是我们圈子难得的好贴!!!!!!
4 楼 SilenceCliff 2007-03-14  
对template="apply_4.ftl这个比较干兴趣。

不知道是否用springmodules整合过jbpm spring hibernate

如有 可否 谈谈看法?
3 楼 whzresponse 2007-03-14  
楼主能不能把java代码也帖出来阿!

相关推荐

    jbpm5完整的例子

    【jbpm5完整的例子】是针对企业业务流程管理(Business Process Management, BPM)的一个实践教程,其中涵盖了jbpm5框架的多个核心功能和用法。jbPM是一个开源的工作流管理系统,它提供了强大的流程定义、执行和监控...

    jbpm3.2.2工作流入门例子

    jbpm3.2.2是jbpm的一个版本,它在当时提供了许多关键功能,如流程定义、流程实例管理、任务管理和事件处理等。本入门例子旨在帮助初学者快速理解和应用jbpm。 在jbpm3.2.2中,工作流引擎是核心组件,它负责解析流程...

    jbpm4.3工作流程管理例子

    jbpm4.3是JBoss Business Process Management (BPM) Suite的一个版本,它是一个开源的企业级BPM平台,用于设计、执行和管理业务流程。在这个"jbpm4.3工作流程管理例子"中,我们将深入探讨jbpm4.3的核心特性和如何...

    jbpm4.4请假例子,eclipse工程

    通过这个例子,开发者可以学习到如何在jbpm4.4中设计和实现一个简单的业务流程,包括流程图的绘制、数据库配置、任务处理和流程实例管理。同时,对于熟悉Eclipse环境的人来说,也可以了解到如何在Eclipse中搭建和...

    一个JBPM工作流例子,JBPM

    JBPM(Java Business Process Management)是一个开源的工作流管理系统,它提供了一整套解决方案,用于设计、执行和管理业务流程。在本示例中,我们将深入探讨如何利用JBPM实现销售批复这一具体场景。 一、JBPM核心...

    jbpm开发入门指南的例子

    总结,jbpm是一个功能强大的业务流程管理框架,通过理解基础概念、搭建开发环境、编写代码实现流程实例的启动和任务处理,可以逐步掌握jbpm的使用。"myjbpm"压缩包中的例子是一个很好的起点,通过实践加深理解,将...

    Jbpm工作流引擎使用例子

    - 创建流程定义后,可以通过Jbpm的工作流API启动一个新的流程实例,这个操作会根据流程定义创建出可执行的实例。 - 运行时,每个实例都有唯一的ID,可以跟踪和管理。 4. **流程实例的获取与管理** - 通过工作流...

    jbpm5 web整合例子

    总的来说,这个"jbpm5 web整合例子"是一个实践性的教程,涵盖了JBPM5与Spring和Hibernate的集成,对于希望在Web应用中实现业务流程自动化和管理的开发者来说,是一个宝贵的资源。通过学习和运行这个例子,开发者可以...

    JBPM例子

    JBPM是一个开源的企业级平台,主要用于管理和执行业务流程。它提供了全面的工作流解决方案,包括流程建模、执行、监控以及集成能力。 在【描述】中提到的“全部原代码”,意味着我们可以深入学习和理解JBPM的各种...

    jbpm4的员工请假例子原码

    【jbpm4的员工请假例子原码】是一个基于jbpm4流程引擎的示例项目,展示了如何在企业中实现一个简单的员工请假流程。这个Web项目是完全开源的,可以通过Eclipse这样的集成开发环境来打开和运行,对于学习和理解jbpm4...

    JBPM4与Spring整合例子代码

    JBPM4(Java Business Process Management 4)是一个开源的工作流管理系统,它提供了业务流程的建模、部署、执行和监控功能。Spring框架则是Java应用开发中的一个核心组件,主要负责依赖注入和面向切面编程,同时也...

    JBPM4.4 工作流 入门 例子

    **JBPM4.4工作流入门例子 - HelloWorld** ...总之,JBPM4.4提供了一个强大且灵活的工作流平台,通过"HelloWorld"这样的入门实例,你可以逐步掌握如何构建和管理业务流程,从而实现企业流程的自动化和优化。

    jbpm5第一个例子

    做好myeclipse集成后,按官方的文档做第一个例子即可。 http://www.mastertheboss.com/jbpm5/jbpm-5-tutorial-first-example 一般不会的问题,从官方找就行,但上面说的也不详细,结果搞了一天也没通,后来把条件...

    jbpm4.4 请假的例子,包含Jar包,实现回退功能可以运行

    在JBPM4.4版本中,我们可以看到一个具体的请假流程示例,该示例包含了实现回退功能的完整代码和Jar包,便于开发者理解和学习。 1. **流程设计** JBPM使用BPMN2.0(Business Process Model and Notation)标准进行...

    jbpm4.4入门编程小例子

    Jbpm(Java Business Process Management)是一个开源的工作流管理系统,主要用于处理业务流程的建模、部署、执行和监控。jbpm4.4是该系统的较早版本,但它仍然是许多开发人员学习工作流管理的基础。在本教程中,...

    jbpm4.0三个例子

    总结来说,jbpm4.0三个例子为Java开发者提供了一个很好的学习平台,通过实际操作可以深入理解jbpm4的工作原理和应用方式。如果你在MyEclipse 7.5或Eclipse 3.42环境中遇到问题,如库文件冲突,可以参考描述中的建议...

    JBPM4.4例子

    JBPM4.4是该系统的一个特定版本,它提供了全面的工作流支持,包括流程设计、执行、监控和优化。本篇文章将详细探讨JBPM4.4的基础知识,以及如何通过jsp和servlet来实现入门级的应用。 **1. 工作流管理系统介绍** ...

    JBPM5工作流引擎 S2SH+JBPM4.4开发工作流的一个完整的请假流程例子

    JBPM5工作流引擎 S2SH+JBPM4.4开发工作流的一个完整的请假流程例子。带有文档教程和所有源码+JAR包。在网上找了半天jbpm6\jbpm7的资料,都很少。所以 环境:Myeclipse2015 JDK1.7 mysql 5.0 Struts2+Spring3.1 1...

    JBPM web(SSH+JBPM) 例子

    【JBPM web(SSH+JBPM)例子】是一个基于Java技术栈实现的工作流管理系统示例,其中SSH代表Spring、Struts和Hibernate这三个流行的Java企业级开发框架的组合,而JBPM则是Business Process Management(业务流程管理...

    jbpm4.4+s2sh请假流程例子

    【jbpm4.4+s2sh请假流程例子】是一个典型的结合了jbpm4.4工作流引擎和Struts2、Spring、Hibernate(S2SH)框架的实战项目,旨在演示如何在企业级应用中实现一个完整的请假流程。在这个例子中,jbpm4.4作为流程管理的...

Global site tag (gtag.js) - Google Analytics