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