使用WEBLOGIC PORTAL规则引擎中实现动态业务逻辑

2008-02-23 08:07:09来源:互联网 阅读 ()

新老客户大回馈,云服务器低至5折

  简介

  业务应用的需求总是随着业务环境的变化趋势而不断地改变。决策很少是一成不变的,并且竞争压力要求业务逻辑的设计和实现具有灵活性,以快速地适应不断变化的需求。通常,对业务逻辑的更改必须由开发人员来完成,然后进行多次彻底的测试,而这将是一个很耗时的过程。在应用程序的修改工作完成后,需要将其重新部署到服务器,需要留出预定的停机时间,以防应用程序对用户不可用。

  对于这个问题,更好的解决方案是通过应用程序之外的一组规则来实现某些业务决策。这些规则并没有被编译到应用程序中,而是在运行时读取并应用。通过这种方式,无需更改代码或者停止正在运行的应用程序就可以改变这些规则。

  WebLogic Portal包括一个基本的规则引擎,用于使WebLogic Platform应用程序从规则获益。尽管该引擎不是功能完备的产品,但我们将展示如何将其与WebLogic Integration Business Processes (JPDs)一起使用来为业务逻辑提供一种灵活且动态的实现机制,从而无需只为了修改规则而重新部署应用程序。

  首先我们来看一下将在全文中使用的示例应用程序,然后介绍如何将规则引擎注入到WLI流程中以实现业务逻辑。然后,我们将更仔细地研究这些规则本身以及如何为业务逻辑定义这些规则,最后将描述在运行中的系统中更改业务规则所使用的机制。

  示例应用程序

  我们将开发一个示例交易应用程序作为在业务流程中使用规则的例子。该交易应用程序是一个金融交易流程的简化版本,该流程使用调用规则引擎的JPD业务流程而构建。该示例应用程序采用了不同的有价证券交易集合,并根据一组由业务定义的规则将其分组成交易块以便执行,或许是为了减少佣金。当然,这里给出的应用程序并不完整,但它已经足以展示如何在现实世界应用程序中使用规则引擎。有完整的源代码可供下载,其中的readme文件提供了构建和运行该应用程序的说明。

  在解释如何开发这样的应用程序之前,我们先通过对门户规则引擎的一些特性的简要概括来了解其工作方式。这里假定读者熟悉一般的规则技术。

  规则引擎及其工作方式

  图1说明了规则引擎的基本情况。该引擎根据一组规则来处理初始的事实集,而这些规则由引擎从外部库中获得。初始事实用于为该引擎填充工作内存。由规则来对工作内存中的事实进行评估,如果满足某条规则的条件,则将执行对应的动作。通常,一个规则动作将向工作内存中添加一条新的事实,并重复该流程直到应用完所有的规则。然后通过可选的过滤器来选择特定类的对象以返回给调用方。可以通过Controls界面访问规则引擎,还可以用它来设置属性(比如规则集文件的位置)。

  图1:该规则引擎是一个由控件包装的EJB。储存库中的规则反复地应用于工作内存中的事实,以获得新的事实。在无法进行继续推理的情况下,对工作内存进行过滤以返回感兴趣的项目。

  从WLI流程调用规则引擎

  让我们从被实现为JPD的交易业务流程开始,来看看如何添加对规则引擎的调用。要在WLI流程中添加规则,可以使用作为WebLogic Portal的一部分而提供的Rules Executor Control(规则执行器控件)。对于本例,我们只使用该控件中所提供的方法和特性的一个子集。关于规则控件的附加说明文档可以在参考资料部分找到。

  此处假定开发人员使用WebLogic Workshop集成开发环境来创建新的流程应用程序。然后可在该应用程序中创建一个流程项目。因为默认情况下门户控件在流程项目中不可用,所以需要将这些控件和规则引擎的EJB导入到应用程序。然后,将控件输入和输出插入到JPD中。在WLI流程中使用门户规则引擎的基本步骤如下:

  导入规则引擎到应用程序:

  • 在应用程序中包含规则引擎。
  • 将p13n_controls库添加到应用程序。

  处理输入和输出:

  • 为输入和结果添加变量。
  • 创建一个Rules Executor控件。
  • 在WLI流程中添加一个Control Send With Return节点。
  • 为创建初始数据编写Java代码。
  • 添加一个流程节点以对结果进行迭代。
  • 创建规则集。

  后面我们将更详细地讨论其中的每一个步骤。

  在应用程序中包含规则引擎

  规则引擎包含在下面的文件中:

  /weblogic81/p13n/lib/p13n_ejb.jar

  要在应用程序中包含该引擎,请右击Workshop集成开发环境中的Modules文件夹,并选择Add Module。导航到该jar文件,并选择Open。

  将p13n_controls库添加到应用程序

  要使得门户规则控件在应用程序中可用,请右击Workshop集成开发环境中的Libraries文件夹,并选择Add Library。该控件位于:

  </weblogic81/p13n/lib/p13n_controls.jar

  导航到此文件,单击 Open 按钮。

  为输入和结果添加变量

  这里使用的Rules Executor控件方法需要一个对象数组作为输入并返回一个结果的迭代器。在Workshop集成开发环境中为这些值创建变量,这样我们就可以在下一步中通过图形用户界面来创建控件。要完成该任务,请为Data Palette中的变量单击Add按钮,键入输入变量的名称,并键入Java类型java.lang.Object[]。使用同样的方式创建Java类型为java.util.Iterator的输出变量。

  创建一个Rules Executor控件

  要创建规则控件,请单击Data Palette中控件的Add按钮。从菜单中选择Portal Controls -> Rules Executor。为控件键入名称,并按下Create按钮。

  在WLI流程中添加一个Control Send With Return节点

  将刚刚创建的控件拖放到流程中以创建一个控件节点来实际调用规则引擎。在示例中,我们将使用控件的evaluateRuleSet()方法。从Send Data面板中,选择前面为方法的输入参数而创建的输入变量。使用Receive Data面板选择返回变量来获取规则执行的结果。在Property Editor窗口中为控件属性键入相应的值。

  为创建初始数据编写Java代码

  在创建了输入变量后,我们还没有对它赋值,所以需要编写代码来完成该任务。这个变量是一个Java对象数组,它提供了输入到规则条件中的初始事实。可以创建一个新的Perform节点来初始化该数组,或者通过使用Source View在Control Send节点中添加代码来设置该变量的值。

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:基于Spring框架的WebSphere应用开发

下一篇:用jsp读远程文件,保存到本地