这可能是一个有点模糊的问题,但现实生活就是这样。
我们公司正在推出SAP系统。我知道他们现在做 Web 服务,所以我们可以同时推出 .NET 来实现我们知道可以在 C# 中做的任何事情。
SAP - .NET 集成过程中的陷阱是什么?我了解 SAP 的逻辑与“标准”编程有很大不同,但我希望将“业务”部分与“演示”部分分开,用 ASP.NET 编写。
这可能是一个有点模糊的问题,但现实生活就是这样。
我们公司正在推出SAP系统。我知道他们现在做 Web 服务,所以我们可以同时推出 .NET 来实现我们知道可以在 C# 中做的任何事情。
SAP - .NET 集成过程中的陷阱是什么?我了解 SAP 的逻辑与“标准”编程有很大不同,但我希望将“业务”部分与“演示”部分分开,用 ASP.NET 编写。
我是 SAP ABAP 和 Microsoft.NET 开发人员。我在一家使用 SAP 和其他平台(例如 Microsoft.NET、Java 和 RoR)创建软件的公司工作。
由于您的公司正在推出 SAP,您应该获得 ECC 6.0 后端,它可以使用 RFC 或 Web 服务。
SAP 有一个称为业务 API(又名 BAPI)的标准 API。您可以在 BAPI 交易中试用它们。
一个很好的例子是:BAPI_USER_GET_DETAIL
.
此 BAPI 负责返回有关任何 SAP 用户的信息。BAPI 只需要一个名为 USERNAME 的输入参数,并返回包含用户信息的不同数据结构,例如电子邮件、名字和姓氏、用户配置文件等。
在 ABAP 中,调用此 BAPI 的模板应该是这样的:
CALL FUNCTION 'BAPI_USER_GET_DETAIL'
EXPORTING
USERNAME = sy-UNAME
* IMPORTING
* LOGONDATA =
* DEFAULTS =
ADDRESS = L_IT_RETURN1
* COMPANY =
* SNC =
* REF_USER =
* ALIAS =
* UCLASS =
* LASTMODIFIED =
* ISLOCKED =
TABLES
* PARAMETER =
* PROFILES =
* ACTIVITYGROUPS =
RETURN = L_IT_RETURN
ADDTEL = i_Tel
* ADDFAX =
* ADDTTX =
* ADDTLX =
* ADDSMTP =
* ADDRML =
* ADDX400 =
* ADDRFC =
* ADDPRT =
* ADDSSF =
* ADDURI =
* ADDPAG =
* ADDCOMREM =
* PARAMETER1 =
* GROUPS =
* UCLASSSYS =
* EXTIDHEAD =
* EXTIDPART =
* SYSTEMS =.
现在,每个 BAPI 也都启用了 RFC(远程函数调用)。这意味着,如果您在应用程序中实现 SAP RFC API,您可以调用 SAP 中设置为启用 RFC 的任何 BAPI 或其他函数。
在旧版本中,您可以使用标准 SAP RFC API,或使用 SAP 向导连接器,例如 SAP .NET 连接器或 SAP Java 连接器。
在较新的版本中,SAP 已将 Web 服务器连接到其 ABAP 应用程序服务器,以便为 ABAP 运行 ITS、BSP 和 WebDynpro 等服务。通过使用此网络服务器,您可以将任何 RFC 发布为 WebService。
但是,根据我的日常经验,SAP R/3 的性能并不是那么好。对两个数字相加并返回结果的函数进行简单的 RFC 调用可能需要 1 到 5 秒,具体取决于服务器的可用性。
发生这种情况主要是因为在使用 SAP .NET 连接器或 WebServices 时碰巧出现了许多抽象级别。
因此,如果您希望您的系统可用于日常交易(例如每天从您的电子商务应用程序中创建 5.000 个客户,或进行大约 40.000 次在线销售),我强烈建议您使用 Java 连接器,或通过以下方式实现 RFC API你自己。
否则,如果您的应用程序将被更少的人在内部使用,我建议您使用 SAP .NET 连接器或 WebServices,因为它们完全面向 GTD。
希望这可以帮助!
(请在下面的链接中添加 http:// 前缀,因为我没有足够的声誉来发布链接:()
RFC API:help.sap.com/printdocu/core/Print46c/EN/data/pdf/BCFESDE4/BCFESDE4.pdf
SAP .NET 连接器:help.sap.com/saphelp_nw04/Helpdata/EN/e9/23c80d66d08c4c8c044a3ea11ca90f/content.htm
SAP Java 连接器:help.sap.com/saphelp_nw04/helpdata/en/6f/1bd5c6a85b11d6b28500508b5d5211/content.htm
使用 ABAP 创建 Web 服务:wiki.sdn.sap.com/wiki/display/stage/Service+Enabling+in+ABAP
如果您的应用程序不需要 SAP Portal 集成,并且您的客户不要求类似 SAP 的外观和感觉,那么您可以自由使用您喜欢的任何表示层。
我不同意在选择进行 SAP 集成时必须使用 sap 工具的立场。像 NWDI 或旧 NWDS 这样的产品显然是一个令人头疼的问题(我不会在这里详细说明,这是一个很长的故事),如果你不是 100% 专注的 sap 集成商,我认为培训人们学习 Webdynpro 是不值得的。
很少有一般性的建议。
对评论的回应: 首先,我认为不应在 sap 中完成报告。报告本质上是丑陋的,并且在其中表现出色。我在考虑不是用户主要工作的小应用程序。诸如报告费用,管理层批准采购请求等。关于在哪里可以找到关于上述障碍的材料。你不能。您必须先用头找到它们。
不要与之抗争。如果您正在实施 SAP,只需实施 SAP。几乎可以保证不值得为此而战。
如果您不喜欢 GUI(BSP、WDJ、WDA),SAP 有工具来处理演示文稿。除非您真的必须这样做,否则我不会尝试实施第 3 方前端。
好好想想使用 .NET 背后的原因:
我参与了许多 .NET / SAP 实施。一方面,我建议不要使用 .NET,而不仅仅是在 ABAP 中编写你想要的东西,但另一方面,它可以很好地工作。正如上面有人提到的,对于小型事务,Web 服务的开销可能会很高,因此请尝试进行设置,以便一次传递相当数量的数据(即满屏)。这样做还意味着 SAP 可以在内部处理整个事务或更多事务,而不是一次传递少量内容并必须处理状态。业务逻辑应在 SAP 内部实现,.NET 部分仅处理数据的呈现/交换。
我将支持有关费用界面的内容。大多数人都使用其他供应商的软件在外部执行此操作,但您不必使用花哨的实时 .NET 东西来导入费用数据,只需一个简单的批处理作业,每天导入一次即可。有时最简单的方法是最好的。
在我的公司,我们处于同样的情况。我们正在使用 .NET 执行与 SAP 的集成项目
您可以通过直接从 .NET 执行 BAPI 函数来避免使用 Web 服务。今天我了解到标准 RFC 函数也可以作为 BAPI 函数公开。
我们正在使用theobald 软件中的ERP Connect直接执行 bapi/RFC 功能,由于在本次讨论中未提及,我认为您可能会受益于了解。
它不是免费的,但我认为它会让开发人员的生活更轻松。
请注意,我与 theobald 软件没有任何关联。