WEB开发网
开发学院WEB开发Jsp 工作流引擎Shark中调用外部程序的方法 阅读

工作流引擎Shark中调用外部程序的方法

 2008-01-05 10:49:01 来源:WEB开发网   
核心提示:最近看了一下工作流引擎Shark,感觉还可以,工作流引擎Shark中调用外部程序的方法,可扩展性和可配置性都很不错,步骤:1、定义流程,则系统将搜索名为applicationName的文件,执行;TestAppInvoke.javapublic class TestAppInvoke {public TestAppIn

  最近看了一下工作流引擎Shark,感觉还可以,可扩展性和可配置性都很不错。
  
  
  
  步骤:
  
  1、 定义流程,主要是relevant date及applications等
  
  2、 编写调用的class文件,见后面
  
  3、 运行Shark,装载TestAppInvoke.XPdl,增加Application Mapping,选择应用程序为TestApp,即在包中定义的应用程序;ToolAgent类型为javaClassToolAgent;Application Name一栏填入Class名称
  
  4、 在PRocess instantiation management中启动流程,此时会自动执行应用程序
  
  
  
  注重事项:
  
  1、应用程序中使用到的数据可定义为Workflow Relevant Date;传入类型可为IN、OUT或INOUT;运行应用程序的节点处增加Extended Attribute,名称为VariableToProcess_UPDATE或VariableToProcess_VIEW,value为参数名;
  
  2、程序需要在classpath里面,使用的程序名称为全名,包括包路径(不带.class);
  
  3、编译后的class文件放到repository/ storedprocedures路径下,注重包的路径;
  
  4、有三种类型的活动节点可调用外部程序
  
  l     活动节点为“Tool”类型,执行者为“System”,开始和结束模式为“AUTOMATIC”;
  
  l     活动节点为“Tool”类型,没有执行者,开始和结束模式为“AUTOMATIC”;
  
  l     活动节点为“Tool”类型,执行者为“System”以外的类型,开始模式为MANUAL,结束模式为AUTOMATIC
  
  5、 假如在Shark中未定义程序映射,Shark将调用默认的ToolAgent,在Shark.conf中可定义;
  
  6、 RuntimeApplicationToolAgent可执行其它外部程序,比如notepad等,此时,传入的application mode假如为0,则Shark会等待应用程序的执行结束;假如不为0,则Shark在应用程序开始后会继续流程的处理;
  
  7、 javascriptToolAgent可用于执行Javascript,application mode为0,则系统将搜索名为applicationName的文件,执行;
  
  TestAppInvoke.java
  public class TestAppInvoke {
  
    public TestAppInvoke() {
    }
  
    public static void execute(AppParameter p1, AppParameter p2, AppParameter p3) {
      JOptionPane.showMessageDialog(null, "初始值:param1=" + p1.the_value
          + "  param2=" + p2.the_value + "  param3=" + p3.the_value);
      
      //这里可设置获取的参数,注重在包定义中应定义参数类型为OUT或INOUT
      //p1.the_mode可获取参数的权限类型:可读、可写还是可读写
      p1.the_value = new String("ABCDE");
      p2.the_value = new Long(12345); //在Shark中,将Integer类型做为Long类型来处理
      p3.the_value = new Boolean(true);     
  
      JOptionPane.showMessageDialog(null, "更改后:param1=" +p1.the_mode +p1.the_value
          + "  param2=" + p2.the_value + "  param3=" + p3.the_value);
    }
  
  }

Tags:工作流 引擎 Shark

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接