SAP第三代增强——BADI解读

BAdI是SAP在标准程序中,为客户自定义逻辑所预留的接口(属于第三代增强),在技术本质上是一个interface,通过实现类的向上继承,完成用户逻辑的调用。

操作BAdI的事务代码:

  • SE18:定义BAdI, 查看BAdI的相关属性。
  • SE19: 实现BAdI,查看BAdI的相关实现。

通常所说的BAdI有两种类型, -

  • Classic BAdI (其在运行时进行实例化), 也称old BAdI;
  • Kernel BAdI (其在编译时便进行实例化), 也称new BAdI; .

Classic BAdI和Kernel BAdI在系统中的定义方式、程序中的调用方式是不同的。

对于Classic BAdI, 其定义是通过SE18 >> Utilities >> Create Classic BAdI来进行的。

在这里插入图片描述

Classic BAdI通过CL_EXITHANDLER=>GET_INSTANCE来获取实例,然后通过实例来调用Interface中的方法。示例代码如下:

  " 对于classic BADI, 其应使用CL_EXITHANDLER=>GET_INSTANCE来获得实例
  DATA: lo_custom_adj TYPE REF TO zif_badi_interface_name.
  DATA: lv_imp_exist TYPE c.
  CALL METHOD CL_EXITHANDLER=>GET_INSTANCE
    EXPORTING
      exit_name              = 'OLD_BADI_NAME'  " BAdI name
      null_instance_accepted = ''
    IMPORTING
      act_imp_existing       = lv_imp_exist
    CHANGING
      instance               = lo_custom_adj    " type ref to BAdI's interface
    EXCEPTIONS
      OTHERS                 = 1.
  IF sy-subrc <> 0.
  ENDIF.
  IF lv_imp_exist IS NOT INITIAL.
    lo_custom_adj->badi_method( ).
  ENDIF.

   
   

对于Kernel BAdI, 通过Enhancement Spot进行创建,也即,先创建Enhancement Spot,然后在Enhancement Spot内部创建BAdI.

在这里插入图片描述

Kernel BAdI通过GET BADI来获取实例,并调用CALL BADI来调用interface中的方法。示例代码如下:

  " Use statement CALL BADI directly (AS 7.0)
  DATA: lo_adj_badi TYPE REF TO zbadi_test_oo_1.
  GET BADI lo_adj_badi.
  IF lo_adj_badi IS BOUND.
    CALL BADI lo_adj_badi->adjust_result
      EXPORTING
        iv_value1 = p_v1
        iv_value2 = p_v2
      CHANGING
        cv_result = lv_result.
  ENDIF.

   
   

在程序中,查找BAdI的常用方法:

  1. 使用事务代码 SE84 :Repository information system
  2. 使用事务代码 SPRO: Customizing Guide, SAP标准发布的BAdI会在相关应用配置点中说明
  3. 在程序中搜索关键字CL_EXITHANDLER=>GET_INSTANCE或关键字GET BADI
  4. 在程序中搜索BAdI相关的接口名称,其接口的命规范通常为IF_EX_
  5. 事务代码CODE_SCANNER, 可指定在特定的package、program中所有相关的字符串

在下文中,给出一个创建、实现、使用 Kernel BAdI的详细步骤 -

Step1: SE18 >> 给定enhancement spot的那么,点击Create.

在这里插入图片描述

Step2: 给出enhancement sport的描述信息,确定。

在这里插入图片描述

Step3: 在enhancement sport内,在左侧点击创建BAdI的图标。

在这里插入图片描述

Step4: 给定BAdI name,并定义BAdI的interface,双击interface name可直接创建interface。

在这里插入图片描述

Step5: 定义interface的相关属性、方法;在此仅定义一个adjust_result的方法作为示例。

在这里插入图片描述

在这里插入图片描述

Step6: 激活interface和enhancement spot, BAdI - ZBADI_TEST_OO_1 创建完成。

在这里插入图片描述

Step7: 实现BAdI >> SE19 >>给定enhancement spot的那么点击创建实现Create Implementation。

在这里插入图片描述

Step8: 输入相关的描述信息。

在这里插入图片描述

Step9: 定义相关的BAdI Implementation和相关的实现类 >> 确定。

在这里插入图片描述

Step10: 双击实现类的名称,创建实现类。

在这里插入图片描述

Step11: 根据业务需求,实现interface中的方法。

在这里插入图片描述

在这里插入图片描述

Step12: 激活实现类。BAdI实现完成。

在这里插入图片描述

Step13: 在local program中,调用并测试BAdI。

PARAMETERS: p_v1 TYPE i DEFAULT 1,
            p_v2 TYPE i DEFAULT 2.

START-OF-SELECTION.

" before calling BAdI
DATA: lv_result TYPE i.
lv_result = p_v1 + p_v2.
WRITE: ‘result is:’ , lv_result.

" Use statement CALL BADI directly (AS 7.0)
DATA: lo_adj_badi TYPE REF TO zbadi_test_oo_1. " BAdI name
GET BADI lo_adj_badi.
IF lo_adj_badi IS BOUND.
CALL BADI lo_adj_badi->adjust_result
EXPORTING
iv_value1 = p_v1
iv_value2 = p_v2
CHANGING
cv_result = lv_result.
WRITE: / ‘After BAdI, the result is:’ , lv_result.
ELSE.
WRITE: / ‘BAdI is not implemented!’.
ENDIF.

    在进入BAdI调整之前result = 3; 经过BAdI中的调整逻辑,其result = 6.

    在这里插入图片描述

    • 3
      点赞
    • 17
      收藏
      觉得还不错? 一键收藏
    • 0
      评论

    “相关推荐”对你有帮助么?

    • 非常没帮助
    • 没帮助
    • 一般
    • 有帮助
    • 非常有帮助
    提交
    评论
    添加红包

    请填写红包祝福语或标题

    红包个数最小为10个

    红包金额最低5元

    当前余额3.43前往充值 >
    需支付:10.00
    成就一亿技术人!
    领取后你会自动成为博主和红包主的粉丝 规则
    hope_wisdom
    发出的红包
    实付
    使用余额支付
    点击重新获取
    扫码支付
    钱包余额 0

    抵扣说明:

    1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
    2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

    余额充值