怎么装载流程定义<!----><o:p></o:p>
上篇文章已经讨论过,流程定义的装载只需要做一次;下面讨论怎么装载的问题。<o:p></o:p>
<o:p> </o:p>
首先给出流程定义的装载的代码,其中的序号对应于后面的解释:<o:p></o:p>
/**
*输入的是流程定义文件名,返回的是流程定义的包ID<o:p></o:p>
*/<o:p></o:p>
public String packageLoad(String xpdlName) throws MyException<o:p></o:p>
{ <o:p></o:p>
//(1)返回库管理器<o:p></o:p>
RepositoryMgr rm = Shark.getInstance().getRepositoryManager();<o:p></o:p>
//(2)用库管理器得到包ID<o:p></o:p>
String pkgId = rm.getPackageId(xpdlName);<o:p></o:p>
//(3)得到包管理器<o:p></o:p>
PackageAdministration pa = Shark.getInstance().getAdminInterface().getPackageAdministration();<o:p></o:p>
if (!pa.isPackageOpened(pkgId))<o:p></o:p>
{<o:p></o:p>
try<o:p></o:p>
{<o:p></o:p>
//(4)装载流程定义<o:p></o:p>
pa.openPackage(xpdlName);<o:p></o:p>
}<o:p></o:p>
catch (Exception e)<o:p></o:p>
{<o:p></o:p>
throw new MyException (e);<o:p></o:p>
}<o:p></o:p>
}<o:p></o:p>
return rm.getPackageId(xpdlName);<o:p></o:p>
}<o:p></o:p>
<o:p> </o:p>
(1)返回库管理器<o:p></o:p>
该功能实际是通过SharkEngineManger来实现的,如下:<o:p></o:p>
public RepositoryMgr getRepositoryManager () {<o:p></o:p>
return SharkEngineManager.getInstance().getObjectFactory().createRepositoryManager();<o:p></o:p>
} <o:p></o:p>
Shark中RepositoryMgr的实现类是RepositoryManager<o:p></o:p>
(2) 用库管理器得到包ID<o:p></o:p>
该功能实现时,实现取出SharkUtilities.EXTERNAL_PACKAGES_REPOSITORY下的全部流程定义,再进行文件名的比较.<o:p></o:p>
(3)得到包ID后,余下的事情交由PackageAdministration来完成<o:p></o:p>
<o:p> </o:p>
作者又名HongSoft,研究领域:1)基于工作流的BPM系统研究2)基于JAVA的信息安全技术.欢迎和大家讨论JAVA相关各方面问题 hongbosoftware@163.com<o:p></o:p>
<o:p> </o:p>
<o:p> </o:p>
<o:p> </o:p>
分享到:
相关推荐
shark工作流xpdl制作工具,版本jawe1.4.2源代码
shark 开发文档 工作流 代码解释 shark 开发文档 工作流 代码解释
工作流引擎shark的技术分析与改进探讨 转自别人的论文,希望对大家对于shark的使用有所帮助。
Shark工作流解决方案英文版.ppt,详细介绍了shark工作流解决方案
shark工作流实例配置说明.为建购这个workflow的细部流程介绍
学习工作流不可缺少的资源,对于研究xpdl非常难得的资料,现在很难找的资料,
吐血分享 非常全面的jbpm和shark工作流引擎对比
Shark 是 Enhydra 开发的完全基于 WFMC 和 OMG 的标准, 使用 XPDL 来进行定义的工作流引擎。本文通过对其最核 心的工作模块调度方式的研究, 根据各种实际测量的数据详细地从两个方面分析了其作用和各种优缺点, 探讨...
工作流基本概念简介及Shark工作流介绍,Jawe工作流建模及Shark工作流引擎使用说明和一个小例子.公司原来工作流内部培训课件!
从j2ee应用服务器,到o/rmapping工具,到这个工作流引擎等等。为什么Shark的持久层采用DODS来实现?就是因为他们是一家人。 Jbpm的靠山是jboss。Jbpm3的持久层采用hibernate3来实现,也是因为这个原因吧。Jbpm3的...
Jawe工作流建模及Shark工作流引擎使用说明
详细介绍在MyEclipse中如何运行shark源代码程序,包括每一步操作
本文对shark工作流引擎进行了分析介绍,通过对企业办公自动化系统的需求分析.给出了系统的功能模块 结构,详细设计了基于web的工作流管理系统。重点阐述了两个关键系统模块一一公文管理子系统和流程自定义模块的实 ...
shark-1.1-2 是Shark最后的开源工作流源代码,以后再也没有了。学习工作流非常好的资料