public class SapClass
{
/// <summary>
///
/// </summary>
/// <param name="fphm">发票号码</param>
/// <param name="fprq">发票开票日期</param>
/// <param name="fkf">付款方</param>
/// <param name="fxqd">分销渠道 </param>
public DataTable nco(string fphm, DateTime fprq, string fkf, char fxqd)
{

//MyBackendConfig config = new MyBackendConfig();
IDestinationConfiguration ID = new MyBackendConfig();

RfcDestinationManager.RegisterDestinationConfiguration(ID);

RfcDestination prd = RfcDestinationManager.GetDestination(PlatRunning.Global.AppSettings.GetValue("SapName"));//SAP系统标识

DataTable dt = nco(prd, fphm, fprq, fkf, fxqd);
RfcDestinationManager.UnregisterDestinationConfiguration(ID);
return dt;

}

/// <summary>
/// SAPTOJS
/// </summary>
/// <param name="prd"></param>
/// <param name="fphm"></param>
/// <param name="fprq"></param>
/// <param name="fkf"></param>
/// <param name="fxqd"></param>
private DataTable nco(RfcDestination prd, string fphm, DateTime fprq, string fkf, char fxqd)
{
RfcRepository repo = null;
try
{
repo = prd.Repository;
}
catch (Exception ex)
{
throw (ex);
}

IRfcFunction companyBapi = repo.CreateFunction("ZSD_SY_FUC_SAPTOJS"); //调用函数名
//设置Import的参数
companyBapi.SetValue("VBELN", fphm);
companyBapi.SetValue("ERDAT", fprq);
companyBapi.SetValue("KUNRG", fkf);
companyBapi.SetValue("ZBJ", fxqd);

companyBapi.Invoke(prd); //执行函数

IRfcTable table = companyBapi.GetTable("IT_JS_EXPORT"); //获取相应的内表IT_JS_EXPORT
//提前实例化一个空的表结构处理
DataTable dt = CreateSapToJSTable();
for (int i = 0; i < table.Count; i++)
{
table.CurrentIndex = i;
DataRow dr = dt.NewRow();
dr["fxqd"] = table[i].GetString("VTWEG");
dr["fphm"] = table[i].GetString("VBELN");
dr["fphh"] = table[i].GetString("POSNR");
dr["fpcjsj"] = table[i].GetString("ERDAT");
dr["khdm"] = table[i].GetString("KUNRG");
dr["khmc"] = table[i].GetString("NAME");
dr["khdzch"] = table[i].GetString("STRAS");
dr["sapddh"] = table[i].GetString("AUBEL");
dr["khddh"] = table[i].GetString("BSTKD");
dr["sapwlh"] = table[i].GetString("MATNR");
dr["khwlh"] = table[i].GetString("KDMAT");
dr["spmc"] = table[i].GetString("ARKTX");
dr["kpm"] = table[i].GetString("TEXT");
dr["jldw"] = table[i].GetString("VRKME");
dr["sl"] = table[i].GetString("FKIMG");
dr["bb"] = table[i].GetString("WAERK");
dr["dj"] = table[i].GetString("KBETR");
dr["jgdw"] = table[i].GetString("KPEIN");
dr["zj"] = table[i].GetString("NETWR");
dr["shl"] = table[i].GetString("MWSK1");
dr["se"] = table[i].GetString("MWSBP");
dr["myxz"] = table[i].GetString("KTGRM");
dt.Rows.Add(dr);
}
return dt;
}

/// <summary>
///
/// </summary>
/// <param name="sapfph">sap发票号</param>
/// <param name="qtfph">生成发票号</param>
public DataTable nco(string sapfph, string qtfph)
{
//MyBackendConfig config = new MyBackendConfig();
IDestinationConfiguration ID = new MyBackendConfig();

RfcDestinationManager.RegisterDestinationConfiguration(ID);

RfcDestination prd = RfcDestinationManager.GetDestination(PlatRunning.Global.AppSettings.GetValue("SapName"));//SAP系统标识
DataTable dt = nco(prd, sapfph, qtfph);
RfcDestinationManager.UnregisterDestinationConfiguration(ID);
return dt;
}

/// <summary>
/// JSTOSAP
/// </summary>
/// <param name="prd"></param>
/// <param name="sapfph"></param>
/// <param name="qtfph"></param>
private DataTable nco(RfcDestination prd, string sapfph, string qtfph)
{
DataTable dt = WriteTableToSAP(prd, sapfph, qtfph);
return dt;
}
#region 写回数据到SAP
private DataTable WriteTableToSAP(RfcDestination rfcDest, string sapfph, string qtfph)
{
RfcRepository repo = rfcDest.Repository;
IRfcFunction funBapi = repo.CreateFunction("ZSD_SY_FUC_JSTOSAP");
//调用函数名
IRfcTable tblROF = funBapi.GetTable("IT_JSTOSAP");
tblROF.Clear();
tblROF.Insert();
tblROF.CurrentRow.SetValue("VBELN", sapfph);
tblROF.CurrentRow.SetValue("JSVBELN", qtfph);
funBapi.SetValue("IT_JSTOSAP", tblROF);
funBapi.Invoke(rfcDest);
//引用回传结果
IRfcTable ReturnTable = funBapi.GetTable("IT_RETURN");
DataTable dtReturn = ReturnMessage();
for (int i = 0; i < ReturnTable.Count; i++)
{
ReturnTable.CurrentIndex = i;
DataRow dr = dtReturn.NewRow();
dr["isSuccess"] = ReturnTable[i].GetString("TYPE");
dr["ReturnMessage"] = ReturnTable[i].GetString("MESSAGE");
dtReturn.Rows.Add(dr);
}
return dtReturn;
}
#endregion
#region 接口参数
public class MyBackendConfig : IDestinationConfiguration
{
public RfcConfigParameters GetParameters(String destinationName)
{
if ("DEV".Equals(destinationName))
{
string strtemp = string.Empty;
RfcConfigParameters parms = new RfcConfigParameters();

parms.Add(RfcConfigParameters.AppServerHost, "192.168.0.122");//SAP主机IP
parms.Add(RfcConfigParameters.SystemNumber, "00");//SAP实例
parms.Add(RfcConfigParameters.User, "SYRFC");//用户名
parms.Add(RfcConfigParameters.Password, "123456"); //密码
parms.Add(RfcConfigParameters.Client, "710");// Client
parms.Add(RfcConfigParameters.Language, "ZH"); //登陆语言

parms.Add(RfcConfigParameters.PoolSize, "5");

parms.Add(RfcConfigParameters.MaxPoolSize, "10");

parms.Add(RfcConfigParameters.IdleTimeout, "60");

return parms;

}

else
return null;

}

public bool ChangeEventsSupported()
{

return false;

}

public event RfcDestinationManager.ConfigurationChangeHandler ConfigurationChanged;

}
#endregion

public DataTable CreateSapToJSTable()
{
DataTable dt = new DataTable();
dt.Columns.Add("fxqd"); //分销渠道
dt.Columns.Add("fphm");//发票号码
dt.Columns.Add("fphh");//发票行号
dt.Columns.Add("fpcjsj");//发票创建时间
dt.Columns.Add("khdm");//客户代码
dt.Columns.Add("khmc");//客户名称
dt.Columns.Add("khdzch");//客户地址(中文)
dt.Columns.Add("sapddh");//sap订单号
dt.Columns.Add("khddh");//客户订单号
dt.Columns.Add("sapwlh");//sap物料号
dt.Columns.Add("khwlh");//客户物料号
dt.Columns.Add("spmc");//商品名称
dt.Columns.Add("kpm");//开票名
dt.Columns.Add("jldw");//计量单位
dt.Columns.Add("sl");//数量
dt.Columns.Add("bb");//币别
dt.Columns.Add("dj");//含税单价
dt.Columns.Add("jgdw");//价格单位
dt.Columns.Add("zj");//总价
dt.Columns.Add("shl");//税率
dt.Columns.Add("se");//税额
dt.Columns.Add("myxz");//贸易性质
return dt;
}
public DataTable ReturnMessage()
{
DataTable dt = new DataTable();
dt.Columns.Add("isSuccess"); //成功与否
dt.Columns.Add("ReturnMessage");//Message
return dt;
}
}

C#调用sap接口及返回数据到sap的更多相关文章

  1. java接口对接——调用别人接口推送数据

    实际开发中经常会遇到要和其他平台或系统对接的情况,实际操作就是互相调用别人的接口获取或者推送数据, 当我们调用别人接口推送数据时,需要对方给一个接口地址以及接口的规范文档,规范中要包括接口的明确入参及 ...

  2. charles_01_打断点修改接口请求&返回数据

    前言 测试过程中,为了模拟某场景测试,经常需要修改接口请求或者返回数据.可通过抓包工具打断点,实现模拟测试场景.常用的抓包工具charles和fiddler均可打断点mock数据.由于小编安装了cha ...

  3. 调用中行接口针对返回报文(xml形式)做相关处理

    最近在对接中行银行接口,在获取返回报文的时候遇到一些问题,现在在这里做个总结 TIP: 在返回报文之前,要对前置机的URL请求,在这期间遇到一个坑,还是通过查看日志才发现问题 在填写转账信息的时候要求 ...

  4. Requests方法 -- 参数关联与JSESSION(上一个接口的返回数据作为下一个接口的请求参数)

    前言 参数关联是接口测试和性能测试最为重要的一个步骤,很多接口的请求参数是动态的,并且需要从上一个接口的返回值里面取出来,一般只能用一次就失效了.最常见的案例就是网站的登录案例,很多网站的登录并不仅仅 ...

  5. Java封装接口统一返回数据模板

    现在大多数都使用前后端分离开发模式,前端通过Ajax请求访问后台服务器,后台返回JSON数据供前端操作,这里编写一个统一返回数据模板类,方便日后操作 public class R extends Ha ...

  6. JQuery的Ajax使用Get,Post方法调用C#WebService并返回数据

    本文将介绍jQuery调用基于.NET Framework 3.5的WebService返回JSON数据,另外还要介绍一下用jQuery调用WebService的参数设置及设置不当所出现的问题,还有出 ...

  7. PHP开发APP接口之返回数据

    首先说明一下客户端APP通信的格式 1.xml:扩展标记语言(1.用来标记数据,定义数据类型,是一种允许用户对自己的标记语言进行定义的源语言,xml格式统一,跨平台和语言,非常适合数据传输和通信,早已 ...

  8. Android调用 .Net Core WebApi 返回数据,用FastJSON解析一直报错。

    问题描述:.Net Core WebApi中用Newtonsoft.Json 把datatable转成json字符串,如:JsonConvert.SerializeObject(table,Forma ...

  9. 远程带参数POST访问接口,返回数据

    1. string token = GetRequest.GetString("token"); int customer_id = GetRequest.GetInt(" ...

随机推荐

  1. 一名合格QA的基本素养

    测试不是无脑的重复劳动.测试与开发一样,先用脑,再动手. 拒绝搬砖,关注技术: 把握需求,极致体验: 把控进度,高效沟通:   测试技术 如果你只会加班,行万里路,也只是个邮差 将程序测"好 ...

  2. MyBatis框架

    MyBatis是支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果集的检索封装.MyBatis可以使用简单的xml或者注解用于 ...

  3. sql server数据库中 smallint, int ,bigint ,tinyint的区别与长度

    smallint  是一种精确的数值数据类型,其精度在算术运算后不变,采用2个字节编码 有符号的 smallint 值的范围是 -2^15-------2^15 -1,即 -32768 ----327 ...

  4. 既约分数-phi

    Description 小明正在学习分数这一章,他想知道对于一个真分数b/a而言,当分母a在[2,N]之间时,存在多少个既约分数,例如当N=4时,有以下几个1/2,1/3,1/4,2/3,3/4这五个 ...

  5. Android基础总结(2)——活动Activity

    1.什么是活动(Activity) 活动(Activity)是一种可以包含用户界面的组件,主要用于和用户进行交互.一个应用程序中可以包含零个或多个活动,但不包含任何活动的应用程序很少见. 2.怎么使用 ...

  6. Maven 的41种骨架

    1: internal -> appfuse-basic-jsf (创建一个基于Hibernate,Spring和JSF的Web应用程序的原型) 2: internal -> appfus ...

  7. Ajax-(get/post/jQuery方式请求)

    < !DOCTYPE html > < html xmlns = "http://www.w3.org/1999/xhtml" > < head &g ...

  8. MFC中release版本和debug版本区别

    最近MFC写了个程序,生成release版,原来正常,后来删掉了些控件再编译运行,结果竟然报内存读写错误,debug却是正常的.后来将“Project   Settings”   中   “C++/C ...

  9. Windows Socket网络编程-2016.01.07

    在使用WSAEventSelect的套接字模型中,遇到了WSAEventSelect返回10038的错误,在定位解决的过程中,简单记录一些定位解决的手段摘要. 使用windows的错误帮助信息,使用命 ...

  10. meta基础知识

    H5页面窗口自动调整到设备宽度,并禁止用户缩放页面 <meta name="viewport" content="width=device-width,initia ...