zoukankan      html  css  js  c++  java
  • .NET连接SAP系统专题:C#调用RFC代码(三)

        本文就说明在C#中如何编写代码来调用SAP中的RFC函数获取数据。(Winform32)

        首先需要引用两个NCO3.0的DLL,下载地址在文后。

        然后在程序代码页面引用:

        using SAP.Middleware.Connector;

        然后所有的代码如下:

    namespace SAP_RFC

    {

        public partial class Form1 : Form

        {

            string MATNR = string.Empty;

            public Form1()

            {

                InitializeComponent();

            }

            public void nco()

            {

                IDestinationConfiguration ID = new MyBackendConfig();

                RfcDestinationManager.RegisterDestinationConfiguration(ID);

                RfcDestination prd = RfcDestinationManager.GetDestination("PRD_000");

                RfcDestinationManager.UnregisterDestinationConfiguration(ID);

                nco(prd);

            }

            public void nco(RfcDestination prd)

            {            

                RfcRepository repo = prd.Repository;

                IRfcFunction companyBapi = repo.CreateFunction("ZRFC_MARA_INFO");   //调用函数名

                companyBapi.SetValue("MATNR", MATNR);   //设置Import的参数

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

                IRfcTable table = companyBapi.GetTable("IT_MARA");  //获取相应的品号内表

                string MAKTX = companyBapi.GetValue("MAKTX").ToString();  //获取品名

                DataTable dt = new DataTable();  //新建表格

                dt.Columns.Add("品号");  //表格添加一列

                for (int i = 0; i < table.RowCount; i++)

                {

                    table.CurrentIndex = i;  //当前内表的索引行

                    DataRow dr = dt.NewRow();

                    dr[0] = table.GetString("MATNR");  //获取表格的某行某列的值

                    dt.Rows.Add(dr);  //填充该表格的值

                }

                if (MATNR == "")

                {

                    for (int i = 0; i < dt.Rows.Count; i++)

                    {

                        this.comboBox1.Items.Add(dt.Rows[i][0].ToString());   //填充下拉框

                    }

                }

                this.label1.Text = MAKTX;   //显示品名

                prd = null;

                repo = null;

            }

            //登陆SAP前的准备工作

            public class MyBackendConfig : IDestinationConfiguration

            {

                public RfcConfigParameters GetParameters(String destinationName)

                {

                    if ("PRD_000".Equals(destinationName))

                    {

                        RfcConfigParameters parms = new RfcConfigParameters();

                        parms.Add(RfcConfigParameters.AppServerHost, "192.168.1.3");   //SAP主机IP

                        parms.Add(RfcConfigParameters.SystemNumber, "00");  //SAP实例

                        parms.Add(RfcConfigParameters.User, "MENGXIN");  //用户名

                        parms.Add(RfcConfigParameters.Password, "5239898");  //密码

                        parms.Add(RfcConfigParameters.Client, "888");  // 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;

            }

            private void Form1_Load(object sender, EventArgs e)

            {

                comboBox1.Items.Clear();

                nco();

                comboBox1.SelectedIndex = 1;

            }

            //当下拉框索引变化的时候传递品号进去查询出品名出来

            private void comboBox1_SelectedIndexChanged(object sender, EventArgs e)

            {

                MATNR = comboBox1.Text.ToString();

                nco();

            }

        }

    }

    我想这个C#代码很简单,我就不多做详细说明了。结果如下:

    SAP中品号信息如下:

    由此可见数据完全OK,调用成功。

    程序在第一次载入的时候有点慢,在链接SAP和登陆。后续在下拉框变化的时候就立马显示出品名出来了,丝毫没有任何停顿。第二次链接SAP的时候大概是不必在登陆了,SAP系统中已有登陆信息,运行T-CODE:SM04

    红色框中这两个即是我们的RFC调用所留下的登录会话。一旦我们的C#程序退出之后,这两个RFC也就退出了。

    如果我们的C#程序是ASP.NET的话,页面关闭之后这个RFC登录信息都还在的。除非IIS关闭,否则只有等到SAP系统超时退出这两个登陆会话了。

    DLL下载地址:

    https://files.cnblogs.com/mengxin523/SAP_DotNetConnector3.zip

  • 相关阅读:
    9.6、Libgdx之罗盘
    9.5、Libgdx加速度计
    9.4、Libgdx简单字符输入
    9.3、Libgdx手势检测
    9.2.2、Libgdx的输入处理之事件处理
    9.2.1、Libgdx的输入处理之轮询
    基于ip的虚拟主机配置——在一台服务器上绑定多个 IP 地址
    解决Nginx出现403 forbidden
    SpringMVC中JSONP的基本使用
    centOS7 tomcat 开机自启 自启动设置
  • 原文地址:https://www.cnblogs.com/saper/p/2135558.html
Copyright © 2011-2022 走看看