.NET连接SAP系统专题:C#调用RFC代码(三)
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了.NET连接SAP系统专题:C#调用RFC代码(三),小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含4202字,纯文字阅读大概需要7分钟。
内容图文
本文就说明在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系统超时退出这两个登陆会话了。
内容总结
以上是互联网集市为您收集整理的.NET连接SAP系统专题:C#调用RFC代码(三)全部内容,希望文章能够帮你解决.NET连接SAP系统专题:C#调用RFC代码(三)所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。