C# 与SAP 的交互

时间:2021-12-24 04:12:03

C# 与sap之间数据 传递

最近 做一个项目 是 把 系统内部数据 上传到 sap 中,由于 没接触 过 sap 对于 sap  还是 很陌生,在 问了 很多人 以及 查找质料 终于 在 上周五 完成了 这个 模块,下面 说一下 具体的 步骤。
最开始 以为 C# 与  sap  是 websevice 之间 通信 的 但是 在 联系 到  开发 sap 的 人  他们说 是  通过 rfc 函数 。
首先 是 需要 引用 两个 dll    
将这两个 dll  引用到 项目下 
之后 引用 命名空间
using SAP.Middleware.Connector;

连接 sap  需要 用户 密码 端口 等
RfcConfigParameters rfcPar = new RfcConfigParameters();

                rfcPar.Add(RfcConfigParameters.Name, LoginInfo.ClientInfo.SapSystem);
                rfcPar.Add(RfcConfigParameters.AppServerHost, LoginInfo.ClientInfo.SapAppServerHost);//服务器ip
                rfcPar.Add(RfcConfigParameters.Client, LoginInfo.ClientInfo.SapClint);端口号
                rfcPar.Add(RfcConfigParameters.User, LoginInfo.ClientInfo.SapUser);//用户名
                rfcPar.Add(RfcConfigParameters.Password, LoginInfo.ClientInfo.SapPassWord);//密码
                rfcPar.Add(RfcConfigParameters.SystemNumber, LoginInfo.ClientInfo.SapSystemNumber);//系统号
                rfcPar.Add(RfcConfigParameters.Language, LoginInfo.ClientInfo.SapLanguage);//语言
                RfcDestination dest = RfcDestinationManager.GetDestination(rfcPar);
		RfcRepository rfcrep = dest.Repository;//开始连接
以上 是 连接 到 sap,连接上 之后 我们 要获取 函数
IRfcFunction myfunc = rfcrep.CreateFunction("sap上的函数名称");
获取函数 之后 这个 函数 会返回 类似于 方法 的 东西 
我们 可以 知道 有 什么 参数 (输出,输入) 当然 这个 在 于 sap 对接的时候 sap的开发人员 会 给 的
 
 

FUNCTION  sap函数名称

(

EXPORT PARAMETER E_FLAG=, IMPORT PARAMETERIS_HEADER=STRUCTURE ZTB_JFI000_HPKG { FIELD MANDT= FIELD SY_SOURCE= FIELD INT_ID=FIELD PKG_UUID= FIELD COMP_CODE= FIELD GEN_TIME=00000000000000 FIELD TOTALROW=0FIELD BUS_DATE=0000-00-00 FIELD PST_DATE=0000-00-00 FIELD PKG_STATUS= FIELDREJ_REASON= FIELD PKG_REMARK= FIELD REC_UPD_DTE=0000-00-00 FIELDREC_UPD_TIME=00:00:00 FIELD REC_UPD_USER= FIELD REC_UPD_TSTAMP=0.0000000 },IMPORT PARAMETER IT_ITEMS_MANU=null, IMPORT PARAMETER I_TESTRUN=, TABLESPARAMETER IT_ERR_MSG=TABLE , TABLES PARAMETER IT_ITEMS


以上 是 获取 的sap 函数 我们 可以 直观 的 看到 参数  以及 参数 的类型  export  表示 输出  import  表示 输入   structure 表示 结构 类型  tables 表示 是 表类型 (自己的理解)

可以根据 参数 和 参数类型 进行 传值 
比如 结构 我们 需要 获取  这个 函数 中的 结构 包含 什么 
IRfcStructure ZTB_JFI000_HPKG = myfunc.GetStructure("结构名称");
以上 是 获取 一个 结构 结构内部我们 也可 知道 有什么 
知道 结构的 字段 我们 就可以给结构 进行赋值
 ZTB_JFI000_HPKG.SetValue("结构中 字段名称", LoginInfo.ClientInfo.SapClint);
myfunc.SetValue("结构名称", ZTB_JFI000_HPKG);
给表 赋值 同理 在 加 一个 循环 即可 还是 写上吧 怕 自己 以后会 用到 到时候 忘记了
 IRfcTable IT_ITEMS_MANU = myfunc.GetTable("IT_ITEMS_MANU");
IT_ITEMS.Append();
                IT_ITEMS.CurrentRow.SetValue("MANDT", LoginInfo.ClientInfo.SapClint);

既然可以赋值 一样可以取值 
//返回标记 S上载成功;E上载失败;
                string isSurce = myfunc.GetString("E_FLAG");//去字符型 参数的值

//取表类型参数的值
IRfcTable IT_ERR_MSG = myfunc.GetTable("IT_ERR_MSG");
                DataTable Table_IT_ERR_MSG = new DataTable();
                Table_IT_ERR_MSG.Columns.Add("PACKG_UUID");
                Table_IT_ERR_MSG.Columns.Add("ROW_ID");
                Table_IT_ERR_MSG.Columns.Add("MSG_STR");
                Table_IT_ERR_MSG.Columns.Add("MSG_TYPE");
                Table_IT_ERR_MSG.Columns.Add("MSG_REF1");
                Table_IT_ERR_MSG.Columns.Add("BUS_UUID");
                for (int i = 0; i < IT_ERR_MSG.Count; i++)
                {
                    IT_ERR_MSG.CurrentIndex = i;
                    DataRow drNew = Table_IT_ERR_MSG.NewRow();
                    drNew["PACKG_UUID"] = IT_ERR_MSG.GetString("PACKG_UUID");
                    drNew["ROW_ID"] = IT_ERR_MSG.GetString("ROW_ID");
                    drNew["MSG_STR"] = IT_ERR_MSG.GetString("MSG_STR");
                    drNew["MSG_TYPE"] = IT_ERR_MSG.GetString("MSG_TYPE");
                    drNew["MSG_REF1"] = IT_ERR_MSG.GetString("MSG_REF1");
                    drNew["BUS_UUID"] = IT_ERR_MSG.GetString("BUS_UUID");
                    Table_IT_ERR_MSG.Rows.Add(drNew);
                }

以上就是 c# 于sap 中 数据 传输 的 总结 希望 对大家 有帮助
注:本人 还不知道 如何 关闭 与 sap 的连接 希望 有 知道 的高手  告诉 我一下  一起 交流 讨论