SAP工具箱 增强限制BW EXCEL用户登陆行为

前言

Analysis for Mircrosoft excel 是 SAP提供的一种基于EXCEL 登陆BW 显示报表的插件. 安装后程序图标如图一所示,报表执行效果如图二所示.

项目中因为大量用户不断重复登陆BW EXCEL报表,导致服务器性能严重下降. 因此希望限制 BW EXCEL报表的登陆行为.

尚未发现SAP的标准解决方案,因此尝试自行开发一个解决方案.

本文主要介绍限制BW EXCEL报表多终端多次登陆的限制方式,避免用户占用过多的服务器资源.

图一

图二

失败的尝试

测试发现,

login/server_logon_restriction

等控制登陆的参数只能针对GUI登陆生效,对于BW EXCEL登陆无效.

尝试通过登陆增强代码限制:

SUSR0001 登陆到 SAP 系统后的用户出口

同样发现该增强只针对GUI登陆有效.

标准登录报错

标准登陆因为用户失效,用户锁等原因报错的逻辑整合在程序 SAPMSYST中, 如图三. SAP通过特殊方式隐藏了这个程序(无法通过SE38查看源代码)

但是可以通过特殊方法查看,修改该程序源代码 详见连接

风险提示: SAPMSYST是ECC/S4/BW等系统的核心程序,一旦修改失误将导致系统不可使用. 请谨慎对待.

可以通过特殊方式修改这个程序,在用户登陆时检查资源占用情况并报错. 但是风险太大. 因此尝试后面的增强点

图三

获取用户登录信息

获取服务器的用户登陆信息(通过跟踪SM04过程可以获取如下代码,用于读取系统中用户登陆的会话,终端,占用内存等信息)

  DATA: session_list TYPE ssi_session_list,

        server_info  TYPE REF TO cl_server_info.

  TRY.

      CREATE OBJECT server_info.

      IF is_system_client = 'X'.

        session_list = server_info->get_session_list( with_application_info = with_appl_info ).

      ELSE.

        session_list = server_info->get_session_list( tenant = sy-mandt with_application_info = with_appl_info ).

      ENDIF.

    CATCH cx_ssi_no_auth.

      MESSAGE e150 WITH TEXT-100.

  ENDTRY.

  SORT session_list BY tenant user_name.

配置表

通过配置表配置以下内容

UNAME用户名/用户组(允许为空,表示所有用户): 优先读取用户的配置,如果没有读取用户组配置,如果没有读取为空的全局配置

  • ALLOW_SESSIONS同时允许的会话数

  • ALLOW_IPS同时登陆的IP地址数

  • ALLOW_MEMORYS允许的内存(M)

  • LIMIT_METHOD限制方式

限制方式帮助信息

  1. 登陆时报系统消息

  2. 限制用户通过角色查找报表

  3. 限制用户搜索报表

  4. 限制用户执行报表(建议维护)

示例:

  • 1234 表示超出使用范围的用户将同时执行四种操作

  • 12 表示超出使用范围的用户执行1.2两种操作

  • 13 表示超出使用范围的用户执行1.3两种操作

  • 14 表示超出使用范围的用户执行1.4两种操作

  • 4 表示超出使用范围的用户执行4一种操作

增强效果

那怎么限制BW用户通过 Analysis for Mircrosoft excel 登陆呢.

根据配置限定登陆次数,限定登陆的终端个数,内存使用量.

对于超出的登陆,

通过函数SM02_GET_UNREAD_MESSAGE 报系统消息

通过函数SUSR_USER_ADDRESS_READ开头隐式增强报错,阻止获取用户授权信息

通过类CL_RSAO_TLOGO_ROOT_DAO 方法 SEARCH_BY_DESCR 开头隐式增强,控制用户搜索报表

通过函数 RSZ_DB_COMP_EXIST 抬头隐式增强,控制用户不能执行报表,通过A类型的报错,提醒用户已超过限制

(最后这个增强可以单独生效)

备注:上述函数可以通过ST05跟踪BW EXCEL报表的执行过程获取.

01

SM02_GET_UNREAD_MESSAGE

这个函数是读取一个系统消息,可以通过增强添加一个系统消息通知用户超过了登录限制

函数末尾调用

呈现效果:EXCEL登陆时,会弹出信息提醒.

02

SUSR_USER_ADDRESS_READ

这个函数用于读取用户信息,包括用户的角色对应的报表信息,限制读取后,用户无法获取授权的报表信息

实现效果:用户无法获取授权的报表信息

03

CL_RSAO_TLOGO_ROOT_DAO

这个类中的方法SEARCH_BY_DESCR 用于搜索报表,限制后,用户无法搜索

实现效果,用户无法搜索报表

04

RSZ_DB_COMP_EXIST

这个函数用户读取报表的信息. 超出登录限制报错后,用户会在EXCEL执行报表时,获得一个报错信息

实现效果:

登录超出限制检查

开发类ZCL_LOGIN_LIMIT

方法 CHECK_LOGIN_LIMIT

源代码未收录在文中, 如果需要参考源代码, 请打赏文章后向微信号392077索取

总结

如果用户无节制的打开多个报表,打开大量数据的明细报表等行为将对服务器的性能产生严重的影响,导致服务器的无响应.

通过增加硬件可以解决一些性能问题.

通过控制用户的的报表行为,则是另一种解决问题的方案. 因为很多用户的报表查询模式还是倾向于获取明细信息,再自行分类汇总.这和系统倡导的报表查询模式刚好相反(系统倡导先获取高纬度的统计信息,再依次降低维度,最后再获取少量明细).

通过上述增强,完美实现了对登陆用户的限制行为,有利于引导用户使用更合理的报表查询模式.降低对系统的资源消耗

  • 限定能使用的会话个数

  • 限定能登陆的终端个数

  • 限定能使用的内存数

  • 配置用户限定的方式

THE

END

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,539评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,911评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,337评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,723评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,795评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,762评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,742评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,508评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,954评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,247评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,404评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,104评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,736评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,352评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,557评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,371评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,292评论 2 352

推荐阅读更多精彩内容