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 的连接 希望 有 知道 的高手 告诉 我一下 一起 交流 讨论