工作流设计和开发小谈
Author:yongtree
现在每天都很累,写作的热情并没有像夏天的火热一样燃烧起来。OA的工作流已经算完成了三分之二了吧,还有传阅和自动路由将在随后的几天和未来的版本升级中逐渐的完善,一直想总结一下,总是被其他事情占据着。今天困的实在不行了,正准备拥抱睡美人的时候,鬼使神差的又看了一下javaeye,看到了一封请教工作流的邮件,本着对朋友负责的态度,让我顺带的写了这个工作流开发的总结。
您好!最近看到了您发的帖子 http://www.iteye.com/topic/211321。我最近也新分配了个web OA的项目。但是我对工作流的东西完全不懂,看了你的帖子后发现您的工作与我将要做的有些相似。因而有些问题想请教下您,希望您有空的话能够帮忙解答下,十分感谢!(因为我对工作流还没很清楚的概念,因此下面问的这几个问题本身可能会有些误区,如果有的话,希望您能够纠正下我认识上的错误。 ^_^ )
1. 自定义的表单如何与后台数据库相关连的呢?是一个表单对应于数据库中的一个表还是其它的方法?
2. 在流程的流转过程中,不同的节点对应着不同的动作,如“发布”、“核对”、“审批”等。这些不同的动作也是放在了自定义表单之中的吗(比如说表单中有三个按钮分别对应这三个动作)?如果不是的话,那么如何保证在不同的节点时有不同的动作呢?
3. 比如说我新发布了一个“请假”的流程后,那么,对于具有“申请假期”权限的用户而言,在web页面中肯定得新添加一个“申请假期”的菜单,通过点击此菜单来进入“申请假期”的页面,否则的话用户无法对这个新的流程进行操作。这一点是要如何实现呢?即后台新建的流程如何为用户的页面添加相应的菜单项?
上面便是朋友在邮件中的一些问题,自己其实也没有太多的经验可以分享,通过工作流的开发和设计,来谈一下自己对工作流的认识吧,希望能给朋友一点帮助。
我们KOA中工作流部分可以说是我进入公司以来,或者说是毕业以来,真正倾注自己心血的一个项目。刚毕业,就接受了这样一个严峻的考验,自己也非常的重视。在开发工作流之前,自己可以说是对工作流一无所知。前期主要是了解、调研工作流系统,通过研究我明白了工作流系统在企业系统中的作用和所处的地位,从技术的层面上,工作流系统应该独立于业务系统,以中间件的形式存在。调研了陕西协同和东方易维的工作流系统,自己进一步了解了工作流系统。对于工作流的功能、难点都有了初步的掌握,当然前面说的那两个都是国内有名的工作流平台产品,功能性和实用性都非常的强大,但是对于每个系统都要有自己侧重的地方,工作流的开发也应该遵循实际的需要来开发,否则便会走上大而不实的歧途。对于.net平台下的工作流,微软公司好像提供的强大的支持,但是在java领域内,多数还是以一些开源的工作流引擎为主,像osworkflow,jbpm,shark这些老牌的工作流引擎,仍然在java领域占有很重要的地位。虽然这些工作流引擎非常强大,有的还提供了图形设计器的功能,但是掌握起来还是有点难度,作为轻量级的工作流系统,完全也没必要使用这些庞大的工作流引擎,所以我们决定自己独立设计和实现工作流引擎。
根据WFMC制定的标准,流程过程描述采用XPDL,简单的说就是采用XML来描述流程过程定义。作为轻量级的工作流实现,我们采用数据库和XML相结合的方式进行设计。XML主要用来描述流程的过程,而过程信息全部保存在数据库中,包括XML描述的过程也保存在数据库中。而且工作流中的运转也通过数据库的关系而实现,XML主要用在图形设计和展示是使用。本着作为中间件的思想架构系统,我采用工作流系统和OA系统没有进行强制的关联,两个系统之间的交互和数据交换采用系统间的接口进行实现。根据WFMC的规范,我设计的工作流引擎实现了五个接口的三个:流程定义接口,流程实例接口,组织机构及参与者接口,工作流没有自己的组织机构模型,通过提供的接口来调用业务系统组织机构的数据。通过JS和xml结合实现简单的图形化设计器,通过对fck在线编辑器的改造,结合数据库的数据存储,实现自定义表单功能。其实大家在设计工作流的时候最好能根据自己业务的需要,那些功能需要,那些功能不需要,那些功能应该砍掉,都应该有一个非常好的判断,并不是越大越好,因为对于你所服务的用户,让他们用的方便这才是最重要的。
唠叨了这么多,针对朋友提的问题,开始简单的阐述我自己的看法。对于自定义表单,肯定需要有一个非常好的物理结构来进行支持,我们看到的表单只是表现形式上的表单,但是在数据的运作中,良好的数据库设计可以很好的实现我们想要的效果。对于自定义表单的结构我们当时想到了两种结构。第一种就是一个表单对应着数据库中的一个表,这对于我们来说最好理解,因为我们开发地绝大部分系统都是这样的结构,但是这对于自定义表单非常的不灵活,所谓自定义表单就是我们能自己随意的定制,而一个表单一个表的结构就非常的固定,需要我们在新建表单时要生成对应的数据表,这在系统的运行中是非常不合适的,如果不想改动程序而实现对表的查询、存储的难度非常大,所以这种方案我认为非常不好。第二种解决方案就是数据库结构尽可能灵活,所以我们把表单进行拆分成表单信息表,到字段信息表,表单实例表,表单字段数据表。通过多表之间的关联,达到灵活处理的目的,并且不受用户自定义表单的影响。第二个问题,我的观点是,工作流和表单也应该是具有一定独立性的,之间通过接口进行交互。表单的主要工作是实现业务数据的存储,而工作流的主要职责是流程的运转,所以动作应该在流程节点上,而不是在表单上。具体每个流程节点对应的表单的只读和隐藏字段的权限,我们只需要在流程设计的时候绑定表单字段和流程节点关联的权限即可。对于第三个问题,我采用的策略是,对于流程分类可以设置访问权限,对于流程可以设置发起者的权限和监管者的权限,对于各个节点可以设置参与者的权限。在有上下级的关系中,权限是具有可继承的,如果上一级你都没有权限,下一级即使没有设置权限,你也没有访问的权限。通过这样,我们就可以通过对用户权限的设置,在前台获取的用户有权限的数据。有些数据你没有权限,菜单上当然就不显示,只显示你有权限的菜单。
不知道这样的解释,大家能不能清楚,由于自己水平有限,也无法深层次的去讲解,希望更多的人能参与进来讨论,让我们的思想因为你的参与而不断地升华。
(该文章作为百洋软件创作实验室官方发布文档,版权归作者本人所有,如有转载请注明出处,谢谢。百洋软件创作实验室官方网站正在积极筹建中,敬请关注)
分享到:
相关推荐
【标题】:谈Activiti工作流在新能源电站中的应用 【摘要】:本文探讨了Activiti工作流引擎在新能源电站生产管理中的应用,旨在解决电站管理过程中的追踪困难、电子文档不足等问题。通过引入Activiti,能够提高电站...
- **工作流(workflow)**:定义业务流程的工作流模型。 - **活动(activity)**:软件开发过程中的具体任务。 - **工件(artifact)**:软件开发过程中的产出物。 - **里程碑(milestone)**:项目进展的关键节点。 ##### ...
### 浅谈OA工作流系统的发展趋势:七个演变 #### 一、引言 随着企业信息化的快速发展,组织流程的优化、技术的进步以及知识管理的需求日益凸显,这推动了OA工作流系统的持续演进。从最初的简单事务处理到如今的智能...
在电子设计领域,开关电源是一种广泛应用的电力转换装置...通过深入学习和理解其工作原理及设计要点,电子设计者可以更好地应对各种挑战,提升产品性能和可靠性。对于初学者和专业人员来说,这部分知识都是不可或缺的。
RUP定义了九个工作流,包括业务建模、需求、分析与设计、实现、测试、配置与变更管理、部署、环境和项目管理。每个工作流对应不同的角色,如业务分析师、系统分析师、软件工程师、测试工程师等,这些角色协同工作以...
3. **核心工作流**:RUP有四个核心工作流,分别是业务建模、需求、架构和实现。这些工作流贯穿整个开发过程,确保所有活动都围绕着业务目标进行。 4. **最佳实践**:RUP集成了许多软件工程的最佳实践,如使用统一...
在首次启动Delphi时,记得调整设置以优化个人工作流,例如关闭不必要的服务,显示编译进度,并保存自定义的布局。 在软件设计阶段,利用PersonalBrain绘制思维导图可以帮助整理思绪,发现潜在的关联和问题。对于...
- **工作流设计**:对于复杂的业务流程,需要设计合理的工作流,以简化用户的操作流程。 - **内容类型定义**:根据网站内容的不同类型,定义相应的字段和属性。 - **用户角色和权限设置**:根据不同的用户群体设定...
平台支持自定义工作流、报表、仪表板以及与其他系统的接口集成,极大地提高了开发效率。 2. 使用操作:开发者可以通过拖拽的方式创建和修改业务流程,设置规则条件,定义数据交互。同时,平台提供了详尽的文档和...
3. **核心工作流**:RUP有四个核心工作流,分别是业务建模、需求、分析与设计、实现与测试。这些工作流贯穿整个项目,确保各个阶段的连贯性。 4. **统一过程**:RUP提供了一套标准化的过程模板,涵盖了软件生命周期...
变电站计算机辅助设计(CAD)应用软件开发是一个将CAD技术应用于变电站设计与分析的领域,它涉及到一系列的技术和方法,用于提高变电站设计的效率和准确性。这项技术的发展与应用对电力系统的设计、规划、施工、维护...
总结来说,《试谈网站开发需求分析报告》从选题背景到技术方案的选择,再到具体的需求分析和系统设计,最后到系统实施,提供了一整套详细的网站开发流程。报告的深入浅出讲解,不仅为网站开发提供了理论上的指导,也...
XP包括测试驱动开发(TDD)、结对编程、持续集成、简单设计、重构和客户参与等实践,旨在提高代码质量,减少缺陷,增强团队协作。 在实际应用中,敏捷过程往往结合多种方法,如Scrum和XP的混合,以适应不同项目的...
本资料包包含的"20060627am--软件开发过程纵横谈(2):敏捷过程.pdf"文件,将为我们深入探讨敏捷过程的核心理念和实践。 **敏捷宣言与价值观** 敏捷宣言于2001年发布,由17位软件开发专家共同签署,它提出了四个...
### 数据库设计经验谈 #### 第一部分:设计数据库之前 **1. 考察现有环境** - **重要性**:在着手设计新的数据库之前,深入理解现有的业务环境和技术架构至关重要。 - **方法论**:这包括但不限于研究现有的业务...
典型工作任务是职业教育专业设置和课程开发的基础性工作,它是一个职业的具体工作领域,包括整个工作过程的计划、目标和实施方法。典型工作任务具有代表性,能全面反映岗位工作的具体内容和实施形式。在设计过程中,...
借助CASE工具进行逻辑设计,能够帮助我们更好地掌握数据库设计中的各个元素,验证用户需求的正确性,以及数据流和工作流的合理性。通过逻辑设计,业务模型和数据模型可以被有效地对齐,从而为后续的物理设计打下坚实...
- **用户界面**:Windows和MacOSX的UI设计和交互习惯有所不同,开发者需要关注用户体验的平台一致性。 6. **总结** - 跨平台开发要求开发者掌握多种平台的知识,理解其系统架构和开发环境的差异,选择合适的编程...
JavaScript API设计是软件开发中的一项关键任务,它直接影响到其他开发者使用我们的代码库的便利性和效率。良好的API设计不仅可以简化开发者的使用过程,还可以提升整个应用的用户体验。以下是从给定文件内容中提炼...