土包子的工作流学
土包子的工作流学
工作流是做什么的?用了一个工作流后,一个系统应该有什么样的效果呢?
工作流的第一个最大的作用就是流程控制。简单的说,就是消灭if-else和switch-case语句。一个使用工作流的系统,在页面和业务类都不应该有太多的if-else和switch-case。这两者都是控制业务流程流转的,而这项工作,是工作流的天职。所以如果系统用了工作流,还是有大量的这种语句,那么这个系统就是失败而毫无意义的。
工作流的第二个作用是状态控制,简单的说,就是消灭setStatus语句。无论pestiNet比FSM的理论先进多少,状态控制始终也是工作流最大好处之一。伴随着流程的流转,在某个点状态都是定好了,我们无须操心,直接打印出来就OK了,这个是对于有一个主业务数据,并关心其状态的业务模型,这个是重中之重。就好像无论你吹嘘社会主义比资本主义先进多少倍,保证人民的温饱才是最重要的。如果我用了工作流,还整天要去关心和update业务表的状态,那无疑是悲哀的。当然,多数据状态是另外一回事。
工作流的第三个作用是角色控制。简单的说,就是消灭if (user == ***) || (roles == ***))这种语句。角色或者用户所能获得的任务,所能进行的操作际窃诠ぷ髁饕胬锩娣祷爻隼吹氖焙颍家丫隽斯伺卸狭耍喜愦耄扌牍匦摹?/p>
为了有效的完成这三个功能,一个工作流引擎,无论基于那种理论进行内部流转,都还应该提供足够的支持,能够灵活的插入业务判断和执行点,根据业务,进行原子业务逻辑判断和操作,角色处理。
这三个基本原则,是一个工作流系统成功应用的标准,如果一个工作流引擎,不能满足大多数业务系统这样的需求,那么无论它的核心理论是多么先进的,那么它也始终是学院派的一个玩具而已,而不是一个对于企业应用系统真正有用的产品。

浙公网安备 33010602011771号