前言

PO(/PI)是SAP公司的一个中间件产品,用来辅助连接SAP系统与外围系统. (当然外围系统之间也可以使用PO). 

一般情况下,异步接口推荐使用PO来确保数据正确抵达目标系统.

PO可以完成一些数据内容转换,群发(一份数据发给多个异构系统),分发(数据区分特征发送给特定的系统)等功能.

本文主要介绍ABAP程序怎么调用PO接口发送数据,怎么处理PO传输过来的数据.

备注:本文只涉及PO与ECC 通过XI方式连接(通道配置如下图).

PO系列之 PO接口在ECC中的开发_公众号

PO系列之 PO接口在ECC中的开发_数据_02


建立连接

建立ECC和PO的连接


详见连接


无峰,公众号:ABAP 技巧与实战​​PO系列之 配置ECC和PO的连接​



注册接口对象

执行TCODE: SPROXY 找到PO和ECC的接口对象.如果找不到,有可能是系统连接问题(SM59中的G类型连接SAP_PROXY_ESR起关键作用).

展开树状结构,根据PO配置采用的命名规则, ECC的组件可能会存在与 PN_ERP 或PN_ECC节点下. (注: PN_<系统>可能只是部分项目的命名规范,具体情况需咨询PO顾问)

PO系列之 PO接口在ECC中的开发_自定义_03


01

出站对象


出站指数据从ECC发出.

进一步展开查找与ECC相关的出站接口对象,如图. 其中的namespaces命名规范及service_consumers命名规范咨询PO顾问. SERVICE_CONSUMERS就是需要引入的PO接口对象. 

如果对象未引入. 显示图标

PO系列之 PO接口在ECC中的开发_公众号_04

对象已引入,显示图标

PO系列之 PO接口在ECC中的开发_自定义_05

PO系列之 PO接口在ECC中的开发_公众号_06






双击未引入的对象,进入向导功能,输入开发类,请求号及前缀(根据命名规范设置前缀,一般用Z<外部系统号>_ )

PO系列之 PO接口在ECC中的开发_公众号_07






继续

PO系列之 PO接口在ECC中的开发_数据_08






点击完成后, 系统创建 service consumer 对象. 需要激活一下.确保激活正确,并看到响应的成功日志.

PO系列之 PO接口在ECC中的开发_数据_09






激活后,系统创建了一个类 

ZTST_CO_SIO_ECC_TST_DEM002 ,类中包含方法SIO_ECC_TST_DEM002 . 调用该方法即可传输数据.

PO系列之 PO接口在ECC中的开发_自定义_10


02

入站对象


入站指数据进入ECC系统

入站对象需要找service providers对象.激活步骤和出站对象一样.

PO系列之 PO接口在ECC中的开发_自定义_11


03

对象修改后重新激活


一般情况下,激活service consumer 对象后,系统会自动激活该对象关联的data types 及message types对象(这两个对象涉及到数据字典定义),如果data types 发生过增删字段的调整, 调整过的对象前会显示图标

PO系列之 PO接口在ECC中的开发_数据_12

此时需要对该对象单独重新激活一下.

PO系列之 PO接口在ECC中的开发_自定义_13


出站程序开发

出站指数据从ECC系统发出.出站程序主要就是调用出站对象的方法实现数据的发出.


01

数据定义部分


参考对象方法中的参数定义所需的变量及节点变量

PO系列之 PO接口在ECC中的开发_公众号_14


02

数据赋值部分


按照嵌套结构 ls_output 给其中的节点赋值(赋值内容参考接口文档).


03

调用前准备部分


PO系列之 PO接口在ECC中的开发_公众号_15


04

消息反馈


设置异步接口的PO反馈


详见链接


无峰,公众号:ABAP 技巧与实战​​PO系列之 消息的确认反馈​

PO系列之 PO接口在ECC中的开发_数据_16


05

接口方法调用部分


图中通过变量拼凑的方法名,动态调用. 实际开发中,直接静态写入调用的方法即可. 调用后,可以读取并记录一下发送数据和GUID的关系.

PO系列之 PO接口在ECC中的开发_公众号_17


入站程序开发

入站指数据从其它系统传入ECC系统.ECC作为数据的接收方. 入站代码主要写在入站代理对象的执行类中. 


01

执行类


入站和出站有点不太一样. 需要找到入站对象的执行类

PO系列之 PO接口在ECC中的开发_数据_18


02

类方法


双击执行类,进入类方法, 在执行类的方法中写代码. (变量定义部分参考出站程序)

PO系列之 PO接口在ECC中的开发_公众号_19

PO系列之 PO接口在ECC中的开发_数据_20


03

获取消息ID部分


获取PO的消息ID

PO系列之 PO接口在ECC中的开发_公众号_21


04

数据处理部分


根据接口文档把接口传递得数据整理成调用BAPI或写入自定义表或产生IDOC所需得内容.


05

业务处理部分


需要注意的是,一般消息的定义方式都允许携带多个单据的信息,这里不建议直接调用BAPI产生后续单据(因为很难确保多单的一致性提交,消息重处理机制是按整个消息处理的).一般写入自定义表或IDOC, 后续程序处理自定义表中内容或IDOC产生业务单据.

PO系列之 PO接口在ECC中的开发_数据_22


06

提交或错误处理


如果调用BAPI发生了错误, 需要把错误传递给给消息监控器

(错误处理的类名,图中的变量CNS_CLASS_NAME,值来自于PO段定义的一个异常消息FALTAL MESSAGE 生成的对象)

备注: 如果写入自定义表后还需要处理, 则该处理程序需要监控并重处理报错的内容

PO系列之 PO接口在ECC中的开发_数据_23

PO系列之 PO接口在ECC中的开发_自定义_24

PO系列之 PO接口在ECC中的开发_数据_25


消息监控

通过TCODE: SXI_MONITOR可以监控出站或入站消息的处理情况.

黑白旗(整体消息图标)表示已经成功发送给PO. 确认状态取决于是否请求PO反馈目标系统的实际发送情况.


详见链接


无峰,公众号:ABAP 技巧与实战​​PO系列之 消息的确认反馈​


如果调用类时,不设置消息反馈. 则该状态无图标.入站消息.

如果在调用BAPI时,抛出了错误. 消息监控中会显示入站报错图标

整体消息图标

PO系列之 PO接口在ECC中的开发_数据_26


入站报错图标

PO系列之 PO接口在ECC中的开发_数据_27


01

查看报错信息


点击入站报错图标,可以看到BAPI报错的具体信息. 下图是所有状态的图标示例.

PO系列之 PO接口在ECC中的开发_自定义_28

PO系列之 PO接口在ECC中的开发_公众号_29


02

消息内容


双击监控器中的条目, 可以看到消息的具体内容,报错信息在这里也能通过点击其它相关节点看到.

PO系列之 PO接口在ECC中的开发_公众号_30


03

消息重处理


对于错误的消息,可以在监控器中启动重新处理(选中错误消息行,重新启动).入站部分的BAPI报错原因解决后, 可以发起重处理,直到消息成功.

PO系列之 PO接口在ECC中的开发_自定义_31


04

队列监控


ECC中的消息处理是通过qrfc实现的. SMQ1,SMQ2 在消息监控中也能起到一定的作用(主要用于重启报错的队列). 


详见链接


无峰,公众号:ABAP 技巧与实战​​SAP小技巧 关于qRFC调用​


总结

PO与ECC之间通讯是通过SPROXY产生的接口对象的代理类. 

  • 出站程序处理调用代理类的方法.
  • 入站程序处理在代理类方法中写入代码.

即可完成ECC与PO数据得交互. 

SXI_MONITOR作为消息监控器, 可以在ECC段确保数据与PO正确的交互.

异步接口的两个重要部分: 日志与报错重处理就是在消息监控器中实现的.

PO与ECC还可以通过RFC或IDOC方式交互数据. 但是一般项目中采用XI方式就足够了.该方式更灵活,可以通过代码实现一些更复杂的逻辑. 推荐使用.

通过XI中的代码产生IDOC也是一个推荐的方式,这样就可以启用IDOC的监控与重处理机制了. 


THE

END





PO系列之 PO接口在ECC中的开发_自定义_32


公众号 : syjf1976_abap

          ABAP开发技巧