前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >ABAP 面试题:如何使用 ABAP 编程语言的 System CALL 接口,直接执行 ABAP 服务器所在操作系统的 shell 命令?

ABAP 面试题:如何使用 ABAP 编程语言的 System CALL 接口,直接执行 ABAP 服务器所在操作系统的 shell 命令?

作者头像
Jerry Wang
发布2022-08-14 10:59:17
3360
发布2022-08-14 10:59:17
举报

假设我们想查看安装了 ABAP 应用服务器的 Linux 系统某个文件目录下的明细,如果直接登录 Linux Shell,使用 `ls -l` 命令即可。

比如:`ls -l //bas/CGC5/src/krn/abap/runt`

其实我们可以使用 ABAP 提供的 CALL 关键字,直接在 ABAP 应用层,发起对操作系统 shell 命令行的调用。后者的执行结果,返回给 ABAP 层,这样 ABAP 应用开发人员就能在此基础上进行一些处理,开发一些工具。

我写了一个简单的 ABAP 报表来包装这个 CALL 关键字的调用:

REPORT zlinux.

PARAMETERS: command TYPE string LOWER CASE DEFAULT 'ls -l //bas/CGC5/src/krn/abap/runt'.

DATA: commtext(120) ,

itab(255) OCCURS 10 WITH HEADER LINE,

lv_folder TYPE string.



START-OF-SELECTION.



PERFORM init.

CALL 'SYSTEM' ID 'COMMAND' FIELD commtext ID 'TAB' FIELD itab[].

LOOP AT itab ASSIGNING FIELD-SYMBOL(<line>).



FIND REGEX '^.*\.c|^.*\.cpp|^.*\.h' IN <line>.

IF sy-subrc = 0.

WRITE: / <line> COLOR COL_NEGATIVE.

DATA(lv_line) = CONV char255( <line> ).

HIDE lv_line.

ELSE.

WRITE: / <line>.

ENDIF.

ENDLOOP.



AT LINE-SELECTION.

PERFORM display_source.



FORM display_source.

SPLIT lv_line AT space INTO TABLE DATA(lt_file).

DATA(index) = lines( lt_file ).

DATA(lv_file_name) = lv_folder && '/' && lt_file[ index ].

DATA(lv_op) = |cat { lv_file_name } |.

SUBMIT zlinux WITH command EQ lv_op.

ENDFORM.



FORM init.

commtext = command.

SPLIT commtext AT space INTO TABLE DATA(lt_table).

CHECK lines( lt_table ) = 3.

lv_folder = lt_table[ 3 ].

ENDFORM.

执行之后,可以指定待执行的 Linux 命令,比如 pwd,这是 Linux 里打印当前工作路径的命令行,即 Print Working Directory 的含义。

结果为 /usr/sap/AG3/DVEBMGS54/work

执行 `ps -aux`, 即可在 ABAP 里, 打印当前操作系统的进程明细:

关于 CALL 的语法,可以查看 SAP 官方帮助[文档](CALL, System Function Call - ABAP Keyword Documentation)。

CALL 关键字一般用于 SAP 系统内部的实现,不能够将其用于 SAP ABAP 应用开发中去。CALL 会调用系统函数 cfunc,可以为 cfunc 指定包含函数名的数据对象,这个数据对象必须是一个 Flat 的 Character like 类型。

该函数必须在sapactab.h文件中输入。修改一个函数或创建一个新函数需要重新编译和链接ABAP内核。因此需要能够访问 C 源代码文件。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2022-08-09,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
腾讯云 BI
腾讯云 BI(Business Intelligence,BI)提供从数据源接入、数据建模到数据可视化分析全流程的BI能力,帮助经营者快速获取决策数据依据。系统采用敏捷自助式设计,使用者仅需通过简单拖拽即可完成原本复杂的报表开发过程,并支持报表的分享、推送等企业协作场景。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档