baiyunjn 发表于 2015-9-19 12:07:30

.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 = table.GetString("MATNR");//获取表格的某行某列的值
  dt.Rows.Add(dr);//填充该表格的值
  }
  if (MATNR == "")
  {
  for (int i = 0; i < dt.Rows.Count; i++)
  {
  this.comboBox1.Items.Add(dt.Rows.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系统超时退出这两个登陆会话了。
  出处(博客地址:http://www.cnblogs.com/mengxin523/)
页: [1]
查看完整版本: .NET连接SAP系统专题:C#调用RFC代码(三) (转)