CPI 与SAP IDOC的连接

1. SAP 端配置

1.1 SALE 定义逻辑系统


1.2 SM59定义与SAP CPI的HTTP连接

此时可以只填写CPI的域名、端口、代理信息,还有CPI的基本鉴权即可

1.3 BD64 创建模型视图

模型视图需要在待推送数据的Client做配置

1.4 生成合作伙伴参数

合作伙伴系统选择1中所创建的逻辑系统,执行即可

1.5 WE21 定义端口

RFC目标选择第2步中所创建的HTTP连接

其他参考下图

1.6 WE20 维护合作伙伴参数

完成第4步之后,会自动生成逻辑系统的伙伴类型

选中待推送IDOC的伙伴类型,添加出站行

消息类型和基本类型选择待推送的IDOC类型

接收方端口填入第5步创建的端口

可以配置多个消息类型,推送时就会根据第3步时的规则自动推送对应的IDOC至端口

2. CPI流程配置

整体配置如下

2.1 配置IDOC地址

2.2 记录IDOC HEADER信息

把HEADER改成application/json,外围系统收到的才是json

SAP的IDOC号和IDOC类型都记录在抬头上,可以暂存到exchange property中,方便后续使用

2.3 分配路由

HEADER抬头中的IDOC类型可以用于区分IDOC目标,客户的往客户的接口推,供应商往供应商的接口推,避免重复开发IFlow

2.4 记录日志

中间这一节跟常规REST2HTTP的配置一模一样,不赘述了

此处写了groovy脚本,用于将外围系统返回的JSON报文收集,并重新封装成新的JSON报文,准备返回给SAP的RFC

注:由于IDOC接口均是异步,只要SAP往CPI接口推送过来了,SAP就视为IDOC成功,但实际上有可能在CPI推送至外围系统时失败,所以需要在CPI上记录外围返回的JSON报文,并返回给SAP的接口做日志记录

groovy脚本如下

source_body就是外围系统返回的json报文

target_body是SAP RFC mapping的报文结构

groovy 复制代码
/* Refer the link below to learn more about the use cases of script.
https://help.sap.com/viewer/368c481cd6954bdfa5d0435479fd4eaf/Cloud/zh-CN/148851bf8192412cba1f9d2c17f4bd25.html

If you want to know more about the SCRIPT APIs, refer the link below
https://help.sap.com/doc/a56f52e1a58e4e2bac7f7adbf45b2e26/Cloud/zh-CN/index.html */
import com.sap.gateway.ip.core.customdev.util.Message;
import java.util.HashMap;
import groovy.json.*;


def Message processData(Message message) {
    // Source Body
    def source_body = message.getBody(String.class);    
    
    // Target Body Structure
    def jsonSlurper = new JsonSlurper();
    def target_body = '{"IF_STATU":"","IFMSG":"","BUSNO":"","IFNUM":"IDOC001","ORSYS":"","BODY":""}';
    def list = jsonSlurper.parseText(target_body);
    
    // Target Body Value
    list.IF_STATU = '01';
    list.IFMSG = '成功';
    list.BUSNO = message.getProperty("IDOC_ID");
    list.IFNUM = 'IDOC001';
    list.ORSYS = 'WMS';
    list.BODY = source_body;
    
    // Return Body
    target_body = JsonOutput.toJson(list);
    message.setBody(target_body);
    return message;
}

下面的内容和常规REST2RFC接口请求一致,不再赘述

2.5 返回SAP SM59,补全HTTP连接

3 测试

3.1 BD14供应商推送

IFlow一切正常

日志记录正常,这个就看项目怎么设计日志平台的了

相关推荐
Z y..6 天前
abap po使用函数入参出参作为接口参数
abap
你好coder7 天前
VSCode连接SAP ABAP开发环境
ide·vscode·编辑器·sap·abap·cds
爱喝水的鱼丶7 天前
SAP-ABAP: Open SQL集合函数COUNT(统计行数)、SUM(数值求和)、AVG(平均值)、MAX/MIN(极值)深度指南
运维·数据库·sql·sap·报表·abap·程序
爱喝水的鱼丶9 天前
SAP-ABAP:ABAP Open SQL 深度解析:核心特性、性能优化与实践指南
运维·开发语言·数据库·sql·性能优化·sap·abap
DeveloperMrMeng10 天前
ABAP SQL更新DB小技巧 WITH INDICATORS
sql·sap·abap
爱喝水的鱼丶12 天前
SAP-ABAP:SAP ABAP OpenSQL JOIN 操作权威指南高效关联多表数据
运维·开发语言·数据库·sap·abap
LilySesy16 天前
【案例总结】幽灵单据——消失的交货单号
数据库·ai·oracle·编辑器·sap·abap
ITVV24 天前
试用SAP BTP 02A:试用SAP HANA Cloud
hana·sap btp·btp·hana cloud
SAP工博科技1 个月前
SAP ERP与微软ERP dynamics对比,两款云ERP产品有什么区别?
microsoft·sap·erp·dynamics
修电脑的猫1 个月前
Performance Monitoring on Production Systems in SAP ERP(ABAP性能优化)
性能优化·abap