ABAP下载病毒扫描Virus Scan 配置方法

网友投稿 635 2022-05-30

当我使用CL_HTTP_ENTITY=>IF_HTTP_ENTITY~GET_DATA从网络下载数据时,遇到异常CX_VSI:

错误原因是数据从网络下载到Netweaver服务器上之后,在服务器上针对实例ldai2ag3_AG3_56找不到对应的病毒扫描Profile。配置表名:vscan_server

从事务码SM51里能发现application server AG3由三个物理实例组成:

而配置表里缺少AG3_56这个实例的profile:

ABAP下载的病毒扫描Virus Scan 配置方法

Solution

将缺失的profile添加到配置表里即可。

执行我github里的这个report:

选中一段markdown文档,ctrl C:

然后直接执行report:

执行完毕:

所有文件都下载到本地文件夹:

这个report使用到的工具类:zcl_crm_cm_tool

通过ABAP代码判断当前系统类型,BYD还是S4 OP还是S4 Cloud

用工具类 CL_COS_UTILITIES

IS_BYD

如果是BYD系统,这个方法的实现会硬编码返回一个true,

在其他系统里则返回false,如图:

IS_SUITE

原理同上,suite系统里返回true

IS_S4H

根据全局结构gv_s4h的不同字段来返回。

managed_cloud_on

public_cloud_on

on_premise_on

gv_s4h通过方法validate_gv_s4h填充。

这三个字段通过对应的business function控制。如果function处于激活状态,则返回true。

CRM WebClient UI的浏览器打印实现

WebClient UI上自带了一个打印按钮,按Ctrl + P后可以生成一个新的页面供打印。

如下图所示。可以看到这个页面里所有的超链接都已经被移除了。

这个页面的生成逻辑如下。

1. 按住ctrl + p之后,会触发WebClient UI框架的按键响应函数thtmlbKeyDown。浏览器传入的事件处理对象里ctrl属性为true,keycode为80(按键p对应的code),意思就是ctrl和p同时按下。

这个响应函数thtmlbKeyDown被注册到整个document对象上,因此您在页面任何位置点击ctrl+p都能得到响应。

从右上角的调用栈能发现crmFrwPrint被调用。crmFrwPrint会打开print.do这个控制器,位于BSP应用bspwd_basics里。

2. 打开print.do控制器的实现类CL_BSPWD_BASICS_PRINT

这个控制器会打开print.html页面

3. 我们按了ctrl+p后生成的页面的内容就是在print.html里生成的。核心代码在函数ppStartScripts里,被thtmlbRegisterOnLoad注册到页面的load事件里,意思是print.html加载时就执行。

thtmlUtil.addEventHandler就是SAP自己封装的事件注册函数,用于多浏览器的兼容支持。

最核心的两个函数:

CreateShield

生成一个height和width为100%的div,背景图片设置成SAP预定义好的1x1.gif。

运行时显示如下:

loadPage

通过window.opener拿到发生了ctrl+p按键的原始页面,然后把其th-l-wcsubheadercontainer下面的所有元素的html直接复制到打印输出页面的header元素下面。

这样就实现了把原始页面的内容搬到了打印输出页面。

然后得到打印页面所有超链接标签,然后把这些标签的href和onclick都置为一个函数体为return false的函数,这样超链接就不再能点击。

var nirvana = new Function ( "return false;" );

ABAP JavaScript web前端 网络

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:C语言之动态内存开辟
下一篇:Jerryscript—让开发者事半功倍
相关文章