本篇介绍 SAP 后端提供的两个调试工具。

  • SAP 外部断点
  • SAP Gateway Service Error Log

外部断点

在程序中设置外部断点,可以在 SAP 侧调试从外部传递的数据。比如,我们用 SEGW 事务码定位到 Create 方法,右键,进入 ABAP 代码。

在 Create 方法中设置一个外部断点:

然后在界面中新增一笔记录,从这个外部断点,可以查看系统新增数据的过程。

有时候,错误可能还到不了data model 的 CRUD 相关方法体代码中。比如,我们知道 SAP client 是 char4 类型的,如果故意在 UI 中,将 client 作为 integer 型。这个时候,出现了错误,但不会进入 create_entity 方法体,外部断点监控不到。

saveCreate: function() {
    var oView = this.getView();
    var oNewEntry = {
        "Mandt": 100,
        "EmpId": oView.byId("EmpId").getValue(),
        "EmpName": oView.byId("EmpName").getValue(),
        "EmpAddr": oView.byId("EmpAddr").getValue()
    };
    ...

页面得到返回的错误:

{
  "error" : {
    "code" : "CX_SXML_PARSE_ERROR/001560AA0E081DEB8CA398CC1690D406",
    "message" : {
      "lang" : "en",
      "value" : "Error while parsing an XML stream"
    },
    "innererror" : {
      "application" : {
        "component_id" : "",
        "service_namespace" : "/SAP/",
        "service_id" : "ZEMPPRJ_SRV",
        "service_version" : "0001"
      },
      "transactionid" : "B853C0BA5D210020E0058FD94B52B6A8",
      "timestamp" : "20170628081051.0048810",
      "Error_Resolution" : {
        "SAP_Transaction" : "Run transaction /IWFND/ERROR_LOG on SAP Gateway hub system and search for entries with the timestamp above for more details",
        "SAP_Note" : "See SAP Note 1797736 for error analysis (https://service.sap.com/sap/support/notes/1797736)"
      },
      "errordetails" : [
      ]
    }
  }
}

关键信息: Error while parsing an XML stream。此时,要用 Error log 来进行错误定位和查找。查找前设置 security level 为 Full。

设置安全级别 (security level)

通过 Internet 网络访问安全设置非常重要,SAP 对外部通过 Gateway service 访问设置了两种级别。需要变更级别,才能看到相关信息:

  • Secure Level : 这个是默认的级别。如果设置为安全级别,有错误发生的时候,很多信息是没有的,比如 service name, HTTP 请求和相应等。所以我们需要改变 security level。

  • Full Level : 这个级别没有限制,可以分析到错误进一步的信息。

如何设置安全级别

有两种方法。方法一是运行事务码 /IWFND/ERROR_LOG ,然后通过菜单:Error log -> Global configuration 来设置。

这种方法,对所有用户,在设置失效恢复到 secure 级别前,一直可用。

方法 2 是变更某一个用户的临时权限,在 2 个小时内有效。运行事务码 /IWFND/TRACES,然后将当前用户的临时 level 设为 Full。

Replay

设置上一步后,重写运行 Web 程序。然后在 /IWFND/ERROR_LOG 事务码中可以通过查看 Request body, Response body 或者 Replay 的方法来发现错误。当然,如果系统反馈的消息不明确,还要依赖开发者的判断。

Logo

权威|前沿|技术|干货|国内首个API全生命周期开发者社区

更多推荐