在网上看到的一篇文章,不知出处,太适合做为我前几个笔记的总结和补充了
Osworkflow定义工作流是通过一个XML文件来完成的,你可以把它取成任何你想要的名字。大致框架如下:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE workflow PUBLIC
"-//OpenSymphony Group//DTD OSWorkflow 2.7//EN"
"http://www.opensymphony.com/osworkflow/workflow_2_7.dtd">
<workflow>
<initial-actions>
...
</initial-actions>
<steps>
...
</steps>
</workflow>
都是按照标准xml指定。通过指定的dtd来校验xml文件。一般需要辅助工具如xmlspy来自动校验xml文件里的错误,这样会方便大家检测xml文件中的错误。
Step和actions
理解这个xml文件的第一个重点在于理解step和actions的在工作流系统中的概念。一个step就是这样的一个概念:一个工作流中所处的不同位置。如在一个文档治理系统中。可以是起草、编辑阶段、发布等等。
Actions指定不同step中的变迁。还是用例子来理解更为形象一些。在一个文档治理系统当中如在“第一个起草”中的“开始第一个起草”和“结束第一个起草”就是actions。
Initial actions 是一个action的非凡类型。在工作流开始时候,是没有状态的,也没有任何step。用户必须利用某个action来开始流程,这个用来开始工作流的action就被指定为initial-actions。
例如,我们假定我们只有一个initial-action,非常简单,如下面:
<action id="1" name="Start Workflow">
<results>
<unconditional-result old-status="Finished" status="Queued" step="1"/>
</results>
</action>
这个action是个action的最简单的例子。他只是简单定义我们需要走想的step。
工作流status
Status用来描述特定step中的一个工作流的状态。如在文档治理系统当中,我们的“第一次起草”step可以有两个statuses,“underway”和“queued”
用“queued”来指示此条已经在“first draft”中排队。没有安排谁来处理此文档,但是已经发出请求。而“underway”是指示一个作者已经从队列中取出此文档并且或许已经上锁。表明正在first draft上工作。
Step实例:在这个例子中有两个actions。第一个action(开始第一个起草)是在一个step中进行。但是,更改状态为underway,第二个action是工作流流转到下一个step,我们假定下一个工作流step为“finish”。
<step id="1" name="First Draft">
<actions>
<action id="1" name="Start First Draft">
<results>
<unconditional-result old-status="Finished" status="Underway" step="1"/>
</results>
</action>
<action id="2" name="Finish First Draft">
<results>
<unconditional-result old-status="Finished" status="Queued" step="2"/>
</results>
</action>
</actions>
</step>
<step id="2" name="finished" />
Old-status这个属性用来指示对于当前state(结束)将要进入哪个history table。在绝大多数情况下,被写为“finished”。
Conditions
Osworkflow有一些内建的conditon。请参看Javadocs,假如需要一个特定的condition。Condition可以接收参数。如本例就接收了一个参数“status”用来指定status
<action id="1" name="Start First Draft">
<restrict-to>
<conditions>
<condition type="class">
<arg name="class.name">
com.opensymphony.workflow.util.StatusCondition
</arg>
<arg name="status">Queued</arg>
</condition>
</conditions>
</restrict-to>
<results>
<unconditional-result old-status="Finished" status="Underway" step="1"/>
</results>
</action>
这样就能保证在initial action被调用后才可以正确执行。因为它需要确信当前status是“queued”。
Functions
接下来,假如我们希望指定一个用户开始first draft,他们变为“owner”为了达到这样的目的,我们需要这样做:
1、在当前context中防止一个“caller”变量
2、 设置result的“owner”属性为call变量。
function是osworkflow的一个非常强大的特征,一个function基本上是一个系列在工作流变迁之间执行的工作,并不影响工作流本身。例如,你能够有个sendmail功能,它的职责就是当一个特定的变迁发生后发送邮件通知。
Functions能够给当前context添加变量。可以在其他functions或者scripts中使用。
Osworkflow 有自己内建function。其中一个比较有用的就是“caller”。这个function的作用就是通过查找当前的能够调用工作流的用户,把该用户以字符串形式命名为caller变量的值。
<action id="1" name="Start First Draft">
<pre-functions>
<function type="class">
<arg name="class.name">com.opensymphony.workflow.util.Caller</arg>
</function>
</pre-functions>
<results>
<unconditional-result old-status="Finished" status="Underway"
step="1" owner="${caller}"/>
</results>
</action>
整合后的结果:
<action id="1" name="Start First Draft">
<restrict-to>
<conditions>
<condition type="class">
<arg name="class.name">
com.opensymphony.workflow.util.StatusCondition
</arg>
<arg name="status">Queued</arg>
</condition>
</conditions>
</restrict-to>
<pre-functions>
<function type="class">
<arg name="class.name">
com.opensymphony.workflow.util.Caller
</arg>
</function>
</pre-functions>
<results>
<unconditional-result old-status="Finished" status="Underway"
step="1" owner="${caller}"/>
</results>
</action>
<action id="2" name="Finish First Draft">
<restrict-to>
<conditions type="AND">
<condition type="class">
<arg
name="class.name">com.opensymphony.workflow.util.StatusCondition
</arg>
<arg name="status">Underway</arg>
</condition>
<condition type="class">
<arg name="class.name">
com.opensymphony.workflow.util.AllowOwNeronlyCondition
</arg>
</condition>
</conditions>
</restrict-to>
<results>
<unconditional-result old-status="Finished" status="Queued" step="2"/>
</results>
</action>
分享到:
相关推荐
总的来说,osworkflow-2.8.0-example.war 提供了一个全面的学习平台,帮助开发者从零开始学习和掌握OSWorkflow工作流程引擎的使用,从而能够高效地在实际项目中实现复杂的工作流程管理功能。无论是对于初学者还是有...
博文链接:https://yanwu.iteye.com/blog/195250
osWorkflow-chinese-manual.pdf这份文档是osWorkflow学习者的宝贵资料,它不仅涵盖了基本概念和原理,还提供了大量实例和代码示例,帮助开发者快速上手并熟练掌握osWorkflow的使用。而www.pudn.com.txt可能是下载...
在OSWorkflow中,工作流被定义为一系列可执行的步骤,这些步骤可以是简单的任务,也可以是复杂的业务逻辑。开发者可以通过定义工作流来控制应用程序中任务的流转,包括任务分配、审批流程、状态变更等。以下是一些...
通过研究这些源代码和文档,开发者可以学习到如何将osWorkflow与Nginx结合,构建一个可扩展、可维护的工作流管理系统,并掌握如何在实际项目中运用这些技术。同时,这也为自定义和优化工作流管理提供了基础,有助于...
建议首先阅读手册的介绍部分,理解OSWorkflow的基本理念和架构,然后逐步学习如何编写流程定义、启动流程实例、集成到应用程序中以及如何扩展和定制OSWorkflow以满足特定需求。 总之,OSWorkflow是Java开发中实现...
标题中的“osworkflow---提供osuser源碼”指的是OSWorkflow框架的一个组成部分——osuser模块的源代码。OSWorkflow是一款开源的工作流引擎,它允许开发者在Java应用中实现复杂的业务流程。osuser模块则是该框架中...
这个压缩包"osworkflow-developer-guide.rar_OSWorkflow ebooks_OsWorkFlow.rar_"包含了关于OSWorkflow的开发者指南和相关资源,非常适合那些想要深入理解并使用OSWorkflow进行开发的人。 **OSWorkflow 概述** ...
《深入解析osworkflow-canvas与Nginx在源码层面的整合应用》 osworkflow-canvas与Nginx,这两个看似不相关的技术在实际开发中却有着紧密的联系。osworkflow-canvas是一款流程设计工具,它是osWorkflow的一部分,...
OSWorkflow,全称为OpenSymphony Workflow,是一款开源的工作流管理系统,用于实现业务流程自动化和管理。这个开发指南是中文版的资源,旨在帮助中国的开发者更好地理解和应用OSWorkflow。以下是关于OSWorkflow的...
这个"osworkflow-example-demo.rar"是一个示例项目,包含了OSWorkflow的源代码和一个经典的实例,适用于初学者学习和理解工作流管理系统的工作原理。由于不包含数据库和流程设计器,因此可能需要用户自行配置和设计...
通过osworkflow项目的学习和实践,总结出的一套osworkflow工作流引擎的学习笔记,供需要使用osworkflow系统的同学们借鉴,谢谢!
这个手册的出现,无疑为中文用户提供了宝贵的资源,便于在国内环境下更好地学习和应用OSWorkflow。 工作流(Workflow)是自动化业务过程的工具,它可以协调人与系统之间的交互,提高组织效率。在OSWorkflow中,你...
使用方法:把mine压缩包解压,把osworkflow-2.8.0-example文件夹放入%TOMCAT_HOME%\webapp下。osworkflow-2.8.0-example.xml放在%TOMCAT_HOME%\conf\Catalina\localhost 当然数据库要配置连接池,名字为jdbc/...
通过部署这个WAR文件,开发者可以学习到osWorkflow的用法,包括如何配置、启动工作流,以及如何与后端数据库交互等。 5. **文档:docs** `docs`目录可能包含了osWorkflow的用户指南、API文档和其他技术文档,对于...
**osworkflow请假系统** ...总结来说,osworkflow请假系统是一个综合的学习资源,涵盖了工作流引擎的使用、数据库设计、Web应用部署等多个IT领域的关键知识点,对于想深入理解工作流管理及其实现的开发者极具价值。