Workflow_客制化BusinessEvent进行消息传递(案例)

2014-06-27 BaoXinjian

一、摘要



在之前的博文中介绍了,如何获取从标砖business event抓取消息,如supplier event,

其实质,就是在supplier的任何create, update, delete的处理,都是通过interface和api进行处理的, 而在处理interface和api的package中都会通过wf_event.raise将消息进行传递出来

再通过其他的package对在队列中的消息进行处理,从而实现消息的异步处理,实现interface的处理的主功能和辅助部分进行异步分离

本文介绍了如何运用完全客制化的business event进行客制化消息的传递

在百度文库中,黄建华大神也有非常详细的介绍

二、案例



案例: 建立一个完全客制化的business event,对该event消息触发和传递进行控制

Step1. 建立客制化表,存放从wf_event.raise传递出来的消息

 1 --Create table
 2 create table BXJ_BES_EVENT_DEMO
 3 (
 4   DEMO_ID                 NUMBER,
 5   MESSAGE_NAME            VARCHAR2(100),
 6   MESSAGE_KEY             VARCHAR2(100),
 7   MESSAGE_CONTENTS        CLOB,
 8   PARAMETER_VALUE1        VARCHAR2(4000),
 9   PARAMETER_VALUE2        VARCHAR2(4000),
10   EVENT_DATE              DATE
11 );
12
13 --Create Sequence
14 CREATE SEQUENCE BXJ_BES_DEMO_S;

Step2. 建立package用以抓取event

 1 --Create Package Header
 2 CREATE OR REPLACE PACKAGE apps.bxj_bes_event_demo_pkg AUTHID CURRENT_USER AS
 3   FUNCTION process_an_event(p_sub_guid IN RAW,
 4                             p_event    IN OUT NOCOPY wf_event_t)
 5     RETURN VARCHAR2;
 6 END;
 7
 8 --Create Package Body
 9 CREATE OR REPLACE PACKAGE BODY apps.bxj_bes_event_demo_pkg AS
10   FUNCTION process_an_event(p_sub_guid IN RAW,
11                             p_event    IN OUT NOCOPY wf_event_t)
12     RETURN VARCHAR2 IS
13     l_demo_rec bxj_bes_event_demo%ROWTYPE;
14   BEGIN
15     SELECT bxj_bes_demo_s.NEXTVAL INTO l_demo_rec.demo_id FROM dual;
16     --get evevent itself
17     l_demo_rec.message_name := p_event.geteventname;
18     l_demo_rec.event_date   := p_event.getsenddate;
19     --we can use this key to transfer message only
20     l_demo_rec.message_key := p_event.geteventkey;
21     --optional, get xml data
22     l_demo_rec.message_contents := p_event.geteventdata;
23     --optional, get parameter
24     l_demo_rec.parameter_value1 := p_event.getvalueforparameter(‘Parameter1‘);
25     l_demo_rec.parameter_value2 := p_event.getvalueforparameter(‘Parameter2‘);
26     --do anything here
27     INSERT INTO bxj_bes_event_demo VALUES l_demo_rec;
28     RETURN ‘SUCCESS‘;
29   EXCEPTION
30     WHEN OTHERS THEN
31       RETURN ‘ERROR‘;
32   END;
33 END;

Step3. 建立Event

Step4.1 建立Subscription

Step4.2 建立subscription中的header信息

Step4.3 建立subscription中的detail信息

三、测试方式1 - 通过页面功能调用event



Test1. 调用event 测试功能

Test2. 输入event key和参数后,raise 该消息

Test3. 确认结果,消息是否传递成功

四、案例测试方式2 - 通过调用脚本触发event



Test1. 调用脚本wf_event触发event

DECLARE
  x_parameters wf_parameter_list_t;
  l_event_data CLOB;
BEGIN
  wf_event.addparametertolist(p_name          => ‘Parameter1‘,
                              p_value         => ‘gavin‘,
                              p_parameterlist => x_parameters);
  wf_event.addparametertolist(p_name          => ‘Parameter2‘,
                              p_value         => ‘bao‘,
                              p_parameterlist => x_parameters);
  l_event_data := ‘<?xml version="1.0" encoding="UTF-8"?><root><Name>Jianhua.Huang</Name></root>‘;

wf_event.RAISE(p_event_name => ‘bxj.business.events.demo‘,
                 p_event_key  => ‘event_key_005‘,
                 p_event_data => l_event_data,
                 p_parameters => x_parameters,
                 p_send_date  => SYSDATE);
END;

Test2. 在结果表中,确认消息是否传递冲给你

********************作者: 鲍新建********************

Workflow_客制化BusinessEvent进行消息传递(案例),布布扣,bubuko.com

时间: 2024-10-12 20:53:50

Workflow_客制化BusinessEvent进行消息传递(案例)的相关文章

BEvent_客制化BusinessEvent通过Workflow接受消息传递(案例)

2014-08-03 Created By BaoXinjian

客制化“*#0*#”恢复出厂设置

客制化"*#0*#"恢复出厂设置 packages/apps/Dialer/src/com/android/dialer/SpecialCharSequenceMgr.java private static final String MMI_RESET_PHONE = "*#0*#";public static final String FORMAT_AND_FACTORY_RESET = "com.android.internal.os.storage.

Dynamics AX 2012 R2 客制化RDP报表参数对话框

    当我们在使用RDP报表时,AX会根据Data Contract,自动生成报表参数对话框上的字段控件.一般情况下,该对话框能够满足我们的需求,但是如果有较为复杂或特殊的需求,就要我们对该对话框进行客制化.     Reinhard这里就有一张报表,需要使用员工编号作为参数.但是AX系统中默认的员工编号EDT,没有提供lookup方法.Reinhard将该员工编号EDT放在报表参数窗体上后,只能手工录入员工编号,不能通过下拉框进行选择.     默认效果是这样:     但是 Reinhar

android STK名称客制化

例如,针对联通定制版,要实现将SIM卡应用名称动态修改成运营商名称: 背景: 1. 由于SAT应用是动态安装的,launcher菜单中的SIM卡应用图标是Stk1.apk的图标. 2. 运营商的名称是存储在: 卡1: TelephonyProperties.PROPERTY_OPERATOR_ALPHA 卡2: TelephonyProperties.PROPERTY_OPERATOR_ALPHA_2 客制化步骤: 1.   从SystemProperty中获取卡的运营商名称 1.1.GB3版本

简单的博客页面客制化

DIY博客的页面 写在前面: 申请了博客第一件事当然是整一个炫酷的界面. 自己水平不够,选了个比较顺眼的皮肤,大部分是套用网上现成的模板完成的. 具体定制的内容: 1.字体的修改 2.版面占比的调整 3.UI细节的修改 4.加入了用户头像 和 一些修饰动图 5.时钟,访问统计,Github conner,天气,Live2d看板娘,分享栏,回到顶部按钮 等小插件 6.图片放大功能 7.3D效果标签云 8.背景图更换 9.背景漂浮线段的动态效果 10.鼠标点击现字的特效 11.QQ联系 和 打赏功能

Oracle EBS12.2 注册客制化应用

一.Oracle APP和DB的基本信息 1.应用和数据库环境: Application Node in Linux7.3 Database Node on Linux 7.3 2.Oracle EBS 应用版本: R12.2.6 on Linux7.3  x_86(64bit) 3.数据库信息: Oracle  Database R12.1.0.2 on Linux 7.3 x_86(64bit) 二.实现步骤 1.在数据库中创建cux用户,并授权.相关命令如下: --(1)创建cux用户  

(8)Launcher3客制化之ContentProvider内容提供者,实现其他应用修改数据库更新等操作

首先添加两个权限 <uses-permission android:name="com.android.launcher3.permission.READ_SETTINGS"/> <uses-permission android:name="com.android.launcher3.permission.WRITE_SETTINGS"/> 这两个是修改 桌面的数据库的权限 不添加就修改不了哦 直接通过内容提供者获取数据, static Ar

(7)Launcher3客制化之,修改单屏幕后,Fix在Hotseat拖动应用删除报错

修改单屏幕后,在workspace里面拖动图标,到删除按钮上松开的时候,报错问题. 并且无法再次显示拖动的图标. 拖动松开手时候触发 public void onDropCompleted(final View target, final DragObject d,             final boolean isFlingToDelete, final boolean success) {         if (mDeferDropAfterUninstall) {//如果要卸载软件

(7)Launcher3客制化之,改动单屏幕后,Fix在Hotseat拖动应用删除报错

改动单屏幕后,在workspace里面拖动图标.到删除button上松开的时候,报错问题. 而且无法再次显示拖动的图标. 拖动松开手时候触发 public void onDropCompleted(final View target, final DragObject d,             final boolean isFlingToDelete, final boolean success) {         if (mDeferDropAfterUninstall) {//假设要