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一切正常

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

相关推荐
LilySesy9 小时前
ABAP+在select的时候,可以A=B A=C B=C这样子JOIN吗?
数据库·sql·ai·excel·sap·abap
LilySesy19 小时前
ABAP+WHERE字段长度不一致报错解决
java·前端·javascript·bug·sap·abap·alv
海阔天空09219 小时前
ABAP S4 新语法 sql with 的用法demo
abap
LilySesy1 天前
ABAP+如果在join的时候需要表1的字段某几位等于表2的字段的某几位,需要怎么做?
服务器·前端·数据库·sap·abap·alv
不想上班的小吕3 天前
SAP EXCEL模板下载导入
excel·sap
大路谈数字化7 天前
SAP PP模块中离散制造
sap·制造·离散·pp
大路谈数字化7 天前
SAP PP模块中重复制造
sap·制造·重复制造·pp
DeveloperMrMeng7 天前
SAP使用abapGit在云环境中迁移开发包
sap·cloud·abapgit·op
拷斤锟8 天前
SAP 实施顾问全景指南
sap·hcm·successfactors
LgZhu(Yanker)9 天前
R/3 销售与分销
大数据·网络·数据库·sap·erp·销售