先理解一下

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, "");
// argsP.Add(RfcConfigParameters.SystemID, "QS7");
argsP.Add(RfcConfigParameters.User, "ATPSUSER");
argsP.Add(RfcConfigParameters.Password, "q123456");
argsP.Add(RfcConfigParameters.Client, "");
argsP.Add(RfcConfigParameters.Language, "zh");
argsP.Add(RfcConfigParameters.PoolSize, "");
argsP.Add(RfcConfigParameters.MaxPoolSize, "");
argsP.Add(RfcConfigParameters.IdleTimeout, ""); //获取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.SetValue("PSPID", ""); //设置参数 项目编号
            invoke.Invoke(sapConfig); //执行函数

            IRfcTable rfcTable = invoke.GetTable("ZIMPSTXS00330"); //获取内表
string message = rfcTable.GetValue("MESSAGE").ToString();
MessageBox.Show(message);
}
}
}

一些传的参数,是结构,就不能用setValue来传参了,要先给结构值

SetStructValue是我封装好的,给结构值的方法,参数结果名字,结构传真字符串,model
fc_invoke.SetValue(0, BAPIACHE09IMPORT)   把结构赋值给,函数对象,索引根据,参数位置决定。
                    IRfcFunction rfc_invoke = configModel.rfcRepository.CreateFunction(configModel.IFUNC);

                    var BAPIACHE09IMPORT = SetStructValue("BAPIACHE09", BAPIACHE09Arr, configModel);
var BAPIACPA09IMPORT = SetStructValue("BAPIACPA09", BAPIACPA09Arr, configModel);
var BAPIACCAHDIMPORT = SetStructValue("BAPIACCAHD", BAPIACCAHDArr, configModel); rfc_invoke.SetValue(, BAPIACHE09IMPORT);
rfc_invoke.SetValue(, BAPIACPA09IMPORT);
rfc_invoke.SetValue(, BAPIACCAHDIMPORT); IRfcTable rfcTable = rfc_invoke.GetTable("RETURN"); //获取内表 string message = rfcTable.GetValue("MESSAGE").ToString();
return message;

封装好的baseClass.cs

using System;
using System.Collections.Generic;
//using System.Linq;
using System.Text;
using System.Reflection;
//using System.Threading.Tasks;
///**************************************************************///
using SAP.Middleware.Connector;
///引用合名空间SAP.Middleware.Connector需要引用sapnco3.0 dll
///sapnco.dll
///sapnco_utils
///**************************************************************/// namespace RC_RFC_LIB
{
/// <summary>
/// RFC接口调用
/// </summary>
public class BaseClass
{ /// <summary>
/// 登录配置
/// </summary>
/// <returns>bool</returns>
public bool rfc_config(Model.baseConfigModel configModel)
{
try
{
//rfc配置
RfcConfigParameters argsP = new RfcConfigParameters();
argsP.Add(RfcConfigParameters.Name, configModel.Name);
argsP.Add(RfcConfigParameters.AppServerHost, configModel.AppServerHost);
argsP.Add(RfcConfigParameters.SystemNumber, configModel.SystemNumber);
argsP.Add(RfcConfigParameters.SystemID, configModel.SystemID);
argsP.Add(RfcConfigParameters.User, configModel.User);
argsP.Add(RfcConfigParameters.Password, configModel.Password);
argsP.Add(RfcConfigParameters.Client, configModel.Client);
argsP.Add(RfcConfigParameters.Language, configModel.Language);
argsP.Add(RfcConfigParameters.PoolSize, "");
argsP.Add(RfcConfigParameters.MaxPoolSize, "");
argsP.Add(RfcConfigParameters.IdleTimeout, "");
//argsP.Add(RfcConfigParameters.AbapDebug, "DEBUG"); //获取rfc配置
configModel.sapConfig = RfcDestinationManager.GetDestination(argsP);
configModel.rfcRepository = configModel.sapConfig.Repository; }
catch (RfcBaseException ex)
{
configModel.resultConfig = ex.Message;
return false;
}
return true;
} #region //item传参
/// <summary>
/// 循环设置函数参数,不包含结构
/// </summary>
/// <param name="rfc_invoke">函数对象</param>
/// <param name="itemArr">参数数组“name@_@value”</param>
public void SetItemParaValue(IRfcFunction rfc_invoke ,string[] itemArr)
{
for (var i = ; i < itemArr.Length; i++)
{
var tmpitVal = itemArr[i].Split(new string[] { "@_@" }, StringSplitOptions.RemoveEmptyEntries);
rfc_invoke.SetValue(tmpitVal[], tmpitVal[]); //设置参数 (参数名,参数值)
} }
#endregion #region Struct类型 字段赋值
/// <summary>
/// Struct类型 字段赋值
/// </summary>
/// <param name="structName">ZAPWZ035 结构字段名</param>
/// <param name="structFieldArr">结构内字段</param>
/// <param name="configModel">配置model</param>
/// <returns>import结构,需要当参数用</returns>
public IRfcStructure SetStructValue(string structName, string[] structFieldArr,Model.baseConfigModel configModel)
{
try
{
IRfcStructure import = null;
//IRfcTable table = rfc_invoke.GetTable("IS_ZAPWZ035");
//ZAPWZ035
//rfc_invoke.SetValue(0,import);
import = configModel.rfcRepository.GetStructureMetadata(structName.Trim().ToUpper()).CreateStructure(); for (var i = ; i < structFieldArr.Length; i++)
{
var tmptableVal = structFieldArr[i].Split(new string[] { "@_@" }, StringSplitOptions.None); import.SetValue(tmptableVal[], tmptableVal[]); //设置参数 (参数名,参数值)
} return import;
}
catch (Exception ex)
{
return null;
} }
#endregion #region property赋值 /// <summary>
/// property赋值
/// </summary>
/// <param name="arrObj">array object</param>
/// <param name="modelObj">model object instance</param>
public void SetPropertyValue(string[] arrObj, object modelObj)
{ var modelInstance = modelObj.GetType();
for (var i = ; i < arrObj.Length; i++)
{
var tmpArr = arrObj[i].Split(new string[] { "@_@" }, StringSplitOptions.None);
foreach (System.Reflection.PropertyInfo py in modelInstance.GetProperties())
{
if (py.Name.ToLower() == tmpArr[].ToLower())
{
modelInstance.GetProperty(py.Name).SetValue(modelObj, tmpArr[]);
}
}
}
}
#endregion }
}

baseConfigmodel.cs

using System;
using System.Collections.Generic;
//using System.Linq;
using System.Text;
//using System.Threading.Tasks;
using SAP.Middleware.Connector; namespace RC_RFC_LIB.Model
{
public class baseConfigModel
{ public string Name { get; set; } //系统名字QH5
public string AppServerHost { get; set; }//系统ip地址
public string SystemNumber { get; set; } //系统实例
public string SystemID { get; set; }//系统id
public string User { get; set; }//用户ATPSUSER
public string Password { get; set; }//密码
public string Client { get; set; }//客户端号800
public string Language { get; set; } //语言zh en
public string IFUNC { get; set; } //接口函数名
public RfcDestination sapConfig { get; set; } //sap登录配置
public RfcRepository rfcRepository { get; set; } //Repository对象
public string resultConfig { get; set; } //配置结果
}
}

C#通过RFC连接sap系统的更多相关文章

  1. Java连接Sap系统调并调用RFC函数

    参考博客:https://blog.csdn.net/qq_36026747/article/details/81287462                   https://www.cnblog ...

  2. .NET连接SAP系统专题:C#调用RFC代码(三)

    本文就说明在C#中如何编写代码来调用SAP中的RFC函数获取数据. 首先需要引用两个NCO3.0的DLL DLL下载地址:http://files.cnblogs.com/mengxin523/SAP ...

  3. .NET连接SAP系统专题:SAP中新建可远程调用的RFC(二)

    何谓RFC,就是一个Function,可以被非SAP系统调用,比如VB,C#,Java等.如果我们在RFC中INCLUDE了相关的业务逻辑,那么我们就可以完全操控SAP中的业务数据了.就像在TTE里, ...

  4. .NET连接SAP系统专题:.NET调用RFC几种方式(一)

    本来今天是要写一篇关于NCO3.0的东西,就是关乎.NET调用SAP的RFC的,支持VS2010和.NET 4.0等.现在网上到处都是充斥着NCO1.X和NCO2.0,需要用VS2003来使用,都是一 ...

  5. .NET利用RFC连接SAP,查询、读取SAP数据

    为黄朴整理!!!!!!!!!!!!!!!!! 在NuGet 添加 sapnco 一个简单的SAPCommand,方法 GetDataTableFromRFCTable 复制于 https://www. ...

  6. .NET连接SAP系统专题:BAPI_TRANSACTION_COMMIT的使用方法(十)

    from:http://scnblogs.techweb.com.cn/mengxin/archives/5.html 为什么.net调用SAP的BAPI接口需要调用BAPI_TRANSACTION_ ...

  7. 创建两个SAP系统之间的RFC信任关系

    一种常见的场景是企业运行着多个SAP系统(ERP/SRM/CRM),用户希望在AA1系统中使用BB1系统的事务.如果直接使用RFC调用另一系统的事务的话,则会弹出登陆框,让用户再次输入帐号密码... ...

  8. C#如何通过NCO3.0来连接SAP并调用SAP中的RFC

    ,这是SAP针对.Net开发的专用组件,安装完成之后在C:\Program Files\SAP\SAP_DotNetConnector3_x86目录下面会有sapnco_utils.dll sapnc ...

  9. VB.NET 与 SAP RFC连接问题点

    与SAP RFC连接,电脑上必须要安装SAP软件,否则会报错ActiveX 输入工单号,无法带出SAP内接口RFC信息. 确认原因为:RFC接口需求的工单参数需要在前面加两位00,例如:1000541 ...

随机推荐

  1. centos 安装教程 服务器配置教程 服务器中安装python 服务器中安装Django 安装MySQL 配置MySQL

    一 .解决python编译安装所需的软件依赖 yum install gcc patch libffi-devel python-devel  zlib-devel bzip2-devel opens ...

  2. webstorm 智能提示忽略大小写

    setting-Editor-General-Code Completion里的 Case sensitive completion: 可以设置只第一个字母敏感.完全敏感或者不敏感. 选择none.. ...

  3. manifold 微分流形上可以定义可微函数、切向量、切向量场、各种张量场等对象并建立其上的分析学,并可以赋予更复杂的几何结构以研究它们的性质。

    小结: 1.流形(英语:Manifolds)一般可以通过把许多平直的片折弯并粘连而成,是局部具有欧几里得空间性质的空间,是欧几里得空间中的曲线.曲面等概念的推广 2.描述一个流形往往需要不止一个“地图 ...

  4. kvm qemu ,ubuntu debian rootfs 通过qemu复现路由器漏洞

    KVM https://www.toutiao.com/i6264303973256135170/?tt_from=weixin&utm_campaign=client_share&t ...

  5. [dpdk][kernel][driver] 如何让DPDK的UIO开机自动加载到正确的网卡上

    0. 前言 开了虚拟机,开始dpdk之前,我每天都干这几件事: [root@dpdk potatos]# modprobe uio [root@dpdk potatos]# insmod /root/ ...

  6. 20165317Java实验三敏捷开发与XP实践

    实验三 敏捷开发与XP实践实验报告 实验目的 安装 alibaba 插件,解决代码中的规范问题.再研究一下Code菜单,找出一项让自己感觉最好用的功能. 在码云上把自己的学习搭档加入自己的项目中,确认 ...

  7. 【PyQt5-Qt Designer】日历(QCalendarWidget)

    日历(QCalendarWidget)+爬虫API调用+自定义发送信号(传入2个参数) 总体介绍 QCalendarWidget类提供了一个基日历小部件,允许用户选择一个日期. 该小部件使用当前的月份 ...

  8. byte数组存储到mysql

    public int AddVeinMessage(byte[] data)//插入数据库 { using (BCSSqlConnection = new MySqlConnection(strCon ...

  9. NOIP国王游戏

    #include<iostream> #include<cstdio> #include<cstdlib> #include<cstring> #inc ...

  10. (1.15)mysql锁问题之InnoDB锁

    关键词:innodb锁,mysql锁 概要: 1.事务的隔离级别 2.InnoDB锁争用 3.innodb锁 [3.1]innodb的行锁模式及加锁方法 其实,默认情况下,mysql 的 select ...