先理解一下
RFC(Romote Function Call)远程函数调用
调用前提:
1.要想通过C# 通过RFC调用SAP端,SAP端要存在RFC远程调用的函数才行(例如SAP端通过SE37创建),要不然是无法调用的。
2.C#调用RFC要有NCO DLL支持(我们使用NCO3.0,VS2013,framework2.0才行否则会报错)
注:好多人64位系统,开发的时候报错,到处找支持64位的NCO3.0,这里可以说一下,是木有的,报错是困为Framework的原因。NCO3.0只支持2.0,在开发环境中改一下就好。
开发背景:
因为要做SAP外围系统IPM接口测试,这个是个异步接口
调用接口之后,返回结果要通过另外一支接口去获得,由于某些原因不好实现,所以采取别一种方法。
直接通过RFC在sap端查接口调用日志表ZIMPSTXS00330(手工查询方法,sap端 se11事务,输入表名,找到MESSAGE字段S代表接口成功,E代码失败)
——————下面直接上代码,其实这个不难——————
引用NCO3.0后
using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; //using System.Linq; using System.Text; using System.Windows.Forms; using SAP.Middleware.Connector; namespace WindowsFormsApplication7 { public partial class Form2 : Form { public Form2() { InitializeComponent(); } private void button1_Click(object sender, EventArgs e) { //rfc配置 RfcConfigParameters argsP = new RfcConfigParameters(); argsP.Add(RfcConfigParameters.Name, "QS7"); argsP.Add(RfcConfigParameters.AppServerHost, "10.5.91.131"); argsP.Add(RfcConfigParameters.SystemNumber, "00"); // argsP.Add(RfcConfigParameters.SystemID, "QS7"); argsP.Add(RfcConfigParameters.User, "ATPSUSER"); argsP.Add(RfcConfigParameters.Password, "q123456"); argsP.Add(RfcConfigParameters.Client, "800"); argsP.Add(RfcConfigParameters.Language, "zh"); argsP.Add(RfcConfigParameters.PoolSize, "5"); argsP.Add(RfcConfigParameters.MaxPoolSize, "10"); argsP.Add(RfcConfigParameters.IdleTimeout, "60"); //获取rfc配置 RfcDestination sapConfig = RfcDestinationManager.GetDestination(argsP); //NCO3.0如果framework不是2.0此处会报错,跟系统64还32无关 RfcRepository rfcRepository = sapConfig.Repository; //调用 IRfcFunction invoke = rfcRepository.CreateFunction("SE11_FUNC"); //调用函数名 ZRFC_MARA_INFO invoke.Invoke(sapConfig); //执行函数 invoke.SetValue("PSPID", ""); //设置参数 项目编号 IRfcTable rfcTable = invoke.GetTable("ZIMPSTXS00330"); //获取内表 string message = rfcTable.GetValue("MESSAGE").ToString(); MessageBox.Show(message); } } }
NCO3.0下载,百度一搜很多的。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
本文向大家介绍C# 如何调用SAP RFC,包括了C# 如何调用SAP RFC的使用技巧和注意事项,需要的朋友参考一下 结构: 安装NuGet包: 以上就是C# 如何调用SAP RFC的详细内容,更多关于C# 调用SAP RFC的资料请关注呐喊教程其它相关文章!
问题内容: 我想创建以下基础结构流: 使用Docker如何实现? 问题答案: 首先,您需要在要ssh- in的映像中安装SSH服务器。您可以对安装了ssh服务器的所有容器使用基础映像。然后,您只需要运行每个容器,即可将ssh端口(默认为22)映射到主机端口(镜像中的远程服务器)到一个端口。即: 然后,如果可以从外部访问主机的端口52022和53022,则可以使用主机的ip(远程服务器)通过ssh在
问题内容: 我开始按照Android所没有使用的教程进行操作,并得到以下信息: 我想这可以归结为几个问题: 我没有创建自己的信任库,但是在网上搜索教程和其他内容时,不确定如何创建信任库。有没有一种方法可以创建或修改信任库以在其中存储所需的证书?(如果有任何不同,我使用的是自签名证书) 如何使SSL握手顺利进行?现在,我得到的错误是: 老实说,我真的不明白这意味着什么。 我需要在Android设备上
我正在使用PhpStorm 2018.3.4,Docker,MySQL和Ubuntu。我试图配置MySQL与Docker容器不成功。 首先,我尝试了以下配置: 它给了我这个错误: 然后,我试了一下: 这个给了我另一个错误。 我错过什么了吗?有没有其他地方我必须配置一些东西? 输出: 这里: 对于命令,这里是描述的链接:https://pastebin.com/9LmeAkc8 下面是docker-
我通过adb自动关闭/打开wifi。 我想根据测试用例禁用/启用wifi 到目前为止,我在这里找到了很好的信息 但是,我想在执行以下命令之前测试连接: 以上命令如果启用则禁用wifi,如果禁用则启用wifi。我想先测试连接,并在需要时采取措施。我想知道是否有一种方法可以使用adb命令。这可以通过编程实现,但我希望通过亚行来实现,使其更加可靠。 此外,以下命令仅在设备为根目录时有效 此外,以下命令在
由于安全原因,一个测试人员不应该在采样器中看到另一个测试人员的jdbc配置详细信息,因为有可能误用用户名、密码和其他详细信息,所以我们有通用的测试机。 1、有没有办法为MySQL、DB2和Microsoft SQL等多个数据库的不同jdbc连接配置设置系统变量。例如:应用程序X使用Microsoft SQL,其中应用程序Y使用DB2,应用程序Z使用MySQL。Y和Z是集成层。数据库URL、JDBC