Web Dynpro的上传问题看来要成为我们的老大难了。
一直以来,我们采用Web Dynrpo ABAP的FILE UPLOAD 控件来上传文件,可令人悲哀的是:竟然不支持对Excel文档的操作。现在我们的用户虽然冠冕堂皇的上传着“Excel”,可实际上文件的类型却是.csv 或是.txt,难免自嘲一把。很难想象SAP这样一家巨头公司,竟然搞不定一个Excel.
秉着中华民族不认输的优良品德,我今天决定“以身试法”。
从R/3找来Function Module: ALSM_EXCEL_TO_INTERNAL_TABLE,从名字就可以知道,这个东东可以用来处理Excle文档,然后转化为内表,有了内表那接下来的操作就水到渠成了。令人郁闷的是,此支Function Module在我们的BI Server中竟然不存在。无奈,自定义一支吧,经过一番倒腾(确实是倒腾,它里面有包含了另一支Function Module,还Include program, structure, Data Element等等多样东东,费神啊),功夫不负有心人,搞定。经过测试,一切正常。
正所谓万事俱备,只欠东风。如今东风已来,就开始操刀了。在SE80建好Web Dynpro Component,各UI Element, Data Binding ,Context Mapping完成,就剩下业务逻辑了,好吧,CALL Function "ALSM_EXCEL_TO_INTERNAL_TABLE"。Importing ,Exporting一切就绪,Run
。 。。。
完蛋,出现异常了。 A:ALSMEX:037
Debug吧,进入此Function Module,发现内部有另外一支FM "CONTROL_FLUSH",再进入,发现还有一支FM : "CONTROL_INIT",再进入(就是要有这种刨根问底的精神),好,最终打入内部了,来看看这段逻辑:
* run the class_constructor * GL 3.12.98
CLASS CL_GUI_OBJECT DEFINITION LOAD.
* Initialize Control Manager............................................
IF THIS_DUMMY_INIT IS INITIAL. IF CL_GUI_OBJECT=>IS_INIT IS INITIAL. MESSAGE S001 RAISING CONTROL_INIT_ERROR.
ELSE. * H_GUI = CL_GUI_OBJECT=>H_GUI. THIS_DUMMY_INIT = 'X'. ENDIF. ENDIF.
不然看出,此段逻辑的处理与SAPGUI有关系,而你的Web Dynpro是WEBGUI,是用Browser来预览的,所以出错了。
好,查看了一些资料,解释下这个东东。因为FM :ALSM_EXCEL_TO_INTERNAL_TABLE它在操作EXCLE文档时会使用Excel OLE Object,而它的使用依赖于SAPGUI,SAPGUI作为一个client program,将从Excel读取到内容传到SAP System。而WEBGUI,我们的Dynpro跑在Browser上就没这个功能了,据说是安全考虑。
讲了大半天,最后还是没给你一个好的结果,或许你是冲着解决此问题来的,非常抱歉,让你失望了,我也很失望。
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/22464099/viewspace-674186/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/22464099/viewspace-674186/