设为首页 收藏本站
查看: 1510|回复: 0

[经验分享] .NET连接SAP系统专题:C#调用RFC代码(三)

[复制链接]

尚未签到

发表于 2015-9-18 09:34:55 | 显示全部楼层 |阅读模式
  本文就说明在C#中如何编写代码来调用SAP中的RFC函数获取数据。
  首先需要引用两个NCO3.0的DLL
  DLL下载地址:http://files.cnblogs.com/mengxin523/SAP_DotNetConnector3.zip
  





  1 //程序代码页面引用:
  2 using SAP.Middleware.Connector;
  3
  4 //代码如下:
  5 namespace SAP_RFC
  6
  7 {
  8
  9     public partial class Form1 : Form
10
11     {
12
13         string MATNR = string.Empty;
14
15         public Form1()
16
17         {
18
19             InitializeComponent();
20
21         }
22
23         public void nco()
24
25         {
26
27             IDestinationConfiguration ID = new MyBackendConfig();
28
29             RfcDestinationManager.RegisterDestinationConfiguration(ID);
30
31             RfcDestination prd = RfcDestinationManager.GetDestination("PRD_000");
32
33             RfcDestinationManager.UnregisterDestinationConfiguration(ID);
34
35             nco(prd);
36
37         }
38
39         public void nco(RfcDestination prd)
40
41         {            
42
43             RfcRepository repo = prd.Repository;
44
45             IRfcFunction companyBapi = repo.CreateFunction("ZRFC_MARA_INFO");   //调用函数名
46
47             companyBapi.SetValue("MATNR", MATNR);   //设置Import的参数
48
49             companyBapi.Invoke(prd);   //执行函数
50
51             IRfcTable table = companyBapi.GetTable("IT_MARA");  //获取相应的品号内表
52
53             string MAKTX = companyBapi.GetValue("MAKTX").ToString();  //获取品名
54
55             DataTable dt = new DataTable();  //新建表格
56
57             dt.Columns.Add("品号");  //表格添加一列
58
59             for (int i = 0; i < table.RowCount; i++)
60
61             {
62
63                 table.CurrentIndex = i;  //当前内表的索引行
64
65                 DataRow dr = dt.NewRow();
66
67                 dr[0] = table.GetString("MATNR");  //获取表格的某行某列的值
68
69                 dt.Rows.Add(dr);  //填充该表格的值
70
71             }
72
73             if (MATNR == "")
74
75             {
76
77                 for (int i = 0; i < dt.Rows.Count; i++)
78
79                 {
80
81                     this.comboBox1.Items.Add(dt.Rows[0].ToString());   //填充下拉框
82
83                 }
84
85             }
86
87             this.label1.Text = MAKTX;   //显示品名
88
89             prd = null;
90
91             repo = null;
92
93         }
94
95  
96
97         //登陆SAP前的准备工作
98
99         public class MyBackendConfig : IDestinationConfiguration
100
101         {
102
103             public RfcConfigParameters GetParameters(String destinationName)
104
105             {
106
107                 if ("PRD_000".Equals(destinationName))
108
109                 {
110
111                     RfcConfigParameters parms = new RfcConfigParameters();
112
113                     parms.Add(RfcConfigParameters.AppServerHost, "192.168.1.3");   //SAP主机IP
114
115                     parms.Add(RfcConfigParameters.SystemNumber, "00");  //SAP实例
116
117                     parms.Add(RfcConfigParameters.User, "MENGXIN");  //用户名
118
119                     parms.Add(RfcConfigParameters.Password, "5239898");  //密码
120
121                     parms.Add(RfcConfigParameters.Client, "888");  // Client
122
123                     parms.Add(RfcConfigParameters.Language, "ZH");  //登陆语言
124
125                     parms.Add(RfcConfigParameters.PoolSize, "5");
126
127                     parms.Add(RfcConfigParameters.MaxPoolSize, "10");
128
129                     parms.Add(RfcConfigParameters.IdleTimeout, "60");
130
131                     return parms;
132
133                 }
134
135                 else return null;
136
137             }
138
139             public bool ChangeEventsSupported()
140
141             {
142
143                 return false;
144
145             }
146
147             public event RfcDestinationManager.ConfigurationChangeHandler ConfigurationChanged;
148
149         }
150
151  
152
153         private void Form1_Load(object sender, EventArgs e)
154
155         {
156
157             comboBox1.Items.Clear();
158
159             nco();
160
161             comboBox1.SelectedIndex = 1;
162
163         }
164
165         //当下拉框索引变化的时候传递品号进去查询出品名出来
166
167         private void comboBox1_SelectedIndexChanged(object sender, EventArgs e)
168
169         {
170
171             MATNR = comboBox1.Text.ToString();
172
173             nco();
174
175         }
176
177     }
178
179 }
  我想这个C#代码很简单,我就不多做详细说明了。结果如下:


DSC0000.jpg
  SAP中品号信息如下:
DSC0001.jpg
  由此可见数据完全OK,调用成功。
  程序在第一次载入的时候有点慢,在链接SAP和登陆。后续在下拉框变化的时候就立马显示出品名出来了,丝毫没有任何停顿。第二次链接SAP的时候大概是不必在登陆了,SAP系统中已有登陆信息,运行T-CODE:SM04
DSC0002.jpg
  红色框中这两个即是我们的RFC调用所留下的登录会话。一旦我们的C#程序退出之后,这两个RFC也就退出了。
  如果我们的C#程序是ASP.NET的话,页面关闭之后这个RFC登录信息都还在的。除非IIS关闭,否则只有等到SAP系统超时退出这两个登陆会话了。
  原文:http://blog.iyunv.com/mengxin523/article/details/6710091

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-115213-1-1.html 上篇帖子: SAP所有模块用户出口(User Exits) 下篇帖子: SAP常用TCODE收藏
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表