- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
利用Visual Basic开发SAP接口程序初探 SAP R/3系统是业界最先进、最稳定的ERP系统,国际和国内大型企业采用该系统的比例遥遥领先于其它ERP系统的总和。SAP R/3内建了二次开发平台,使用的开发语言叫做ABAP,是一种类似于COBOL的编程语言。ABAP在报表输出方面功能相对较弱(只能按行打印在屏幕上或者导出到Excel中处理),所以日常工作中经常需要在外部开发程序。通过程序接口自动读取SAP R/3的数据表(视图),在外部进行处理和利用水晶报表等工具生成符合中国人习惯的报表样式。 SAP R/3的接口方式主要有RFC、IDOC、BAPI三种,本文要介绍的是相对比较简单的RFC(Romote Function Call,远程函数调用)。SAP系统RFC调用的原理其实很简单,有一些类似于三层构架的C/S系统,第三方的客户程序通过接口调用SAP内部的标准或自定义函数,获得函数返回的数据进行处理后显示或打印。下面是RFC调用的模型:
本文主要不是讨论SAP R/3函数的开发,因为使用SAP的公司一般都有专门的ABAP开发人员。大家如果有机会接触ABAP平台,可以通过事务代码SE37进入ABAP开发平台的函数编制器进行函数开发测试。如图: 下面主要以VB为例介绍一下SAP接口RFC的开发思路。在SAP客户端SAP Gui Client安装的时候,注意选择安装附带的SDK包(最保险是选择完全安装)。RFC接口程序开发,主要用的是SAP.Functions这个控件,通过控件在外部程序模拟SAP Gui Client的用户登录和函数调用,然后返回函数的值。请看下面的程序片段和重点注解(尤其是test_Click()):
Private Sub Command1_Click() 定义R/3用户名和密码变量(用户名应由SAP管理员开运行函数的权限) Dim logname As String * 22, password As String * 22 Call logonr3(logname, password) 调用SAP登录界面程序 If logflag Then 调用生产、开发系统开关 StatusBar1.Visible = True StatusBar1.SimpleText = 正在登录SAP R/3系统... Dim R3AppServer As String, R3Client As String, R3SystemNo As String If Form2.opPRD.Value Then 以下服务器参数请根据客户配置情况更改 R3AppServer = 生产系统服务器IP R3Client = 800 生产系统集团代码 R3SystemNo = 00 生产系统号 Else R3AppServer = 开发系统服务器IP R3Client = 101 R3SystemNo = 00 End If Unload Form2 释放 Form2 , 所有控件及值不可用 Set Functions = CreateObject(Sap.Functions) 创建RFC的本地对象 Set Connect = Functions.Connection 设置连接 Connect.ApplicationServer = R3AppServer 赋值服务器IP Connect.Client = R3Client 赋值SAP集团代码 Connect.Language = ZH 置SAP系统界面中文 Connect.User = Trim(logname) 赋值SAP登录用户名 Connect.password = Trim(password) 赋值SAP登录用户密码 Connect.SystemNumber = R3SystemNo 赋值SAP系统号 If Not Connect.Logon(0, True) Then 软件登录SAP并判断 MsgBox 登录SAP R/3失败,请重新登录!, vbOKOnly + vbExclamation, 系统提示 Command1.SetFocus Else 登录SAP成功 Command1.Enabled = False Command2.Enabled = True test.Enabled = True End If StatusBar1.SimpleText = StatusBar1.Visible = False End IfEnd S
文档评论(0)