http://scnblogs.techweb.com.cn/dario/
http://www.cnblogs.com/03081626/archive/2010/04/06/1705781.html
使用SAP标准功能实现复杂ABAP对象在不同系统间的迁移(转载)
使用SAP标准功能实现复杂ABAP对象在不同系统间的迁移
http://scnblogs.techweb.com.cn/dario/archives/2.html
通常情况下,对于单纯的报表类型的简单构造的源代码,我们很容易实现其在不同系统之间的共享,COPY and PASTE 然后创建激活就可以了,但是对于不是由纯字符型构成的开发对象,比如说一个包含了很多DYNPRO的复杂程序或者是很多嵌套结构从而需要依次分别手动创建的大型程序,要实现从一个系统到另一个系统的共享就不是特别的直观。
SAPLink(http://wiki.sdn.sap.com/wiki/display/ABAP/SAPlink)就是为了这个目的而开发的一个开源工具,但是在使用之前我们必须先安装这个工具,这又造成了一些不方便,假设我们开发了一些工具,需要在不同的项目中使用,如果我们每次都要先安装一个SAPLink,再用SAPLink来安装我们的工具的话,就会显得特别麻烦。
下面将会向大家介绍一个完全使用SAP标准功能来实现这个功能的具体步骤,假设的场景是我们有两个演示系统RS6和CM1,我们在系统RS6上开发了很多ABAP对象,现在希望能够将RS6上的ABAP对象快速的移植到CM1上面来(RS6和CM1完全不相关,也没有传输路径)。
1. 登录原始系统RS6, 运行事务代码 SE01,我们可以看到需要移植的ABAP对象。
2.下一步是Release这个CR (change request)RS6K907449, 这一步完成之后我们
就会看到在Application Server上两个文件已经生成了(T_CODE; AL11)。
第一个文件, Cofiles: /usr/sap/trans/cofiles/K907449.RS6
第二个文件, Data: /usr/sap/trans/data/R907449.RS6
3.然后我们使用CG3Y这个事务代码将这两个文件下载到本地,他们就会在后面的传输中被用到.
*对于另外一个文件R907449.RS6执行同样的操作即可
4. 得到这两个文件之后,我们在RS6系统上的工作就完成了,现在登录到另外一个系统CM1,接下来的一步是使用事务代码CG3Z来讲这两个文件上传到Application Server上指定的目录,这个目录就是每个SAP系统专门用于存放传输文件的目录。每个系统的路径也许会不一样,此处的路径在其他系统上不一定起作用。
*对于文件R907449.RS6, 将路径改为‘//SAPCM01/sapmnt/trans/data/R907449.RS6′.即可
5.文件上传之后我们需要使用事务代码STMS将这个CR RS6K907449导入到Import Queue中。
在弹出的对话框中输入这个CR:
6.在CR被添加到Import Queue里面后,我们就可以正式开始导入了:
7.导入成功后我们双击这个CR就可以看到所有的ABAP对象都被移植到了新的系统
可以看到采用SAP标准功能实现复杂ABAP对象的迁移是比较简单的,我们不需要安装任何的第三方工具,我们所要做的仅仅是创建一个CR将所有对象包含,然后Release这个CR, 得到两个文件( KXXXXXX.SystemId & RXXXXXX.SystemId ),最后按照传输步骤导入到新系统即可.这种方法对于很多可重用的对象的迁移是非常有帮助的,同时由于我们使用的是SAP标准功能,所以对于几乎所有类型的ABAP对象都有很好的支持。
http://www.itpub.net/thread-1168695-1-1.html
how to download a service object attachment to app server?
下面是我收集的一些信息:
1、CG3Z 可以将文件从本地上传到服务器目录
2、CG3Y 可以将服务器中文件下载到本地目录
3、AL11 可以查看服务器目录文件
4、下载到本地的函数为:SO_OBJECT_DOWNLOAD
不幸的是函数SO_OBJECT_DOWNLOAD不能将附件下载到服务器或FTP服务器,试图修改SO_OBJECT_DOWNLOAD函数中的用到的函数SCMS_R3_TO_CLIENT第105行,以CG3Z中用于上传至服务器函数C13Z_RAWDATA_WRITE 替换,虽然可以上传至SAP服务器,但由于二者采用的格式编码不同,从服务器再下载到本地时无法读取,所以宣告失败。(以word文档为例
PARAMETERS: PA_ONAME TYPE SY-UNAME. "receiver
PARAMETERS: PA_SNAME TYPE SY-UNAME. "sender
PARAMETERS: PA_DATUM TYPE SY-DATUM. "sender date
PARAMETERS: PA_DESCR TYPE SO_OBJ_DES."description
PARAMETERS: PA_FNAME TYPE RLGRAP-FILENAME."file path
START-OF-SELECTION.
DATA: TAB LIKE TABLE OF SOLIX.
DATA: REC LIKE LINE OF TAB.
DATA: USR LIKE SOUDNAMEI1.
DATA: USR_DATA LIKE SOUDATAI1.
DATA: G_OBJ TYPE SOODK.
USR-SAPNAME = PA_ONAME.
* 读取用户inbox
CALL FUNCTION 'SO_USER_READ_API1'
EXPORTING
USER = USR
IMPORTING
USER_DATA = USR_DATA
EXCEPTIONS
USER_NOT_EXIST = 1
PARAMETER_ERROR = 2
X_ERROR = 3
OTHERS = 4.
IF SY-SUBRC <> 0.
ENDIF.
DATA: WA_CON LIKE SOFOLENTI1,
CONTENT LIKE TABLE OF SOFOLENTI1.
*读取文件
CALL FUNCTION 'SO_FOLDER_READ_API1'
EXPORTING
FOLDER_ID = USR_DATA-INBOXFOL
TABLES
FOLDER_CONTENT = CONTENT
EXCEPTIONS
FOLDER_NOT_EXIST = 1
OPERATION_NO_AUTHORIZATION = 2
X_ERROR = 3
OTHERS = 4
.
IF SY-SUBRC <> 0.
ENDIF.
READ TABLE CONTENT INTO WA_CON WITH KEY OBJ_DESCR = PA_DESCR
SEND_NAM = PA_SNAME
SEND_DATE = PA_DATUM.
G_OBJ-OBJTP = WA_CON-OBJECT_ID+0(3).
G_OBJ-OBJYR = WA_CON-OBJECT_ID+3(2).
G_OBJ-OBJNO = WA_CON-OBJECT_ID+5(12).
DATA: OBJ LIKE TABLE OF SOOD5,
WA_OBJ LIKE SOOD5.
* 附件id取得
CALL FUNCTION 'SO_ATTACHMENT_LIST_READ'
EXPORTING
OBJECT_ID = G_OBJ
TABLES
OBJECTS = OBJ
EXCEPTIONS
SYSTEM_FAILURE = 1
COMMUNICATION_FAILURE = 2
OTHERS = 3.
IF SY-SUBRC <> 0.
ENDIF.
READ TABLE OBJ INTO WA_OBJ INDEX 1.
DATA: ATT LIKE SOATTLSTI1-ATTACH_ID.
DATA: LC_NAME(12) TYPE C.
LC_NAME = PA_ONAME.
CONCATENATE USR_DATA-INBOXFOL
WA_CON-OBJECT_ID
PA_ONAME
WA_OBJ-OBJTP
WA_OBJ-OBJYR
WA_OBJ-OBJNO
INTO ATT RESPECTING BLANKS.
* 读取附件
CALL FUNCTION 'SO_ATTACHMENT_READ_API1'
EXPORTING
ATTACHMENT_ID = ATT
TABLES
CONTENTS_HEX = TAB[]
EXCEPTIONS
ATTACHMENT_NOT_EXIST = 1
OPERATION_NO_AUTHORIZATION = 2
PARAMETER_ERROR = 3
X_ERROR = 4
ENQUEUE_ERROR = 5
OTHERS = 6
.
IF SY-SUBRC <> 0.
ENDIF.
CHECK TAB IS NOT INITIAL.
* 上传附件
* DATA: PA_FNAME TYPE RLGRAP-FILENAME.
*
* CONCATENATE '/usr/sap/' SY-SYSID '/SC_TEST.XLS' INTO PA_FNAME.
OPEN DATASET PA_FNAME FOR OUTPUT IN BINARY MODE .
LOOP AT TAB INTO REC.
TRANSFER REC-LINE TO PA_FNAME.
ENDLOOP.
CLOSE DATASET PA_FNAME.