声明:原创作品,转载时请注明文章来自SAP师太技术博客( 博/客/园www.cnblogs.com):www.cnblogs.com/jiangzhengjun,并以超链接形式标明文章原始出处,否则将追究法律责任!原文链接:http://www.cnblogs.com/jiangzhengjun/p/4265588.html

FTP文件到文件服务器
服务器上文件读写

20.3.     FTP

以下是两个FTP服务配置表:

下面是函数参数列表:

FUNCTION zmm_data_to_ftp.
*"----------------------------------------------------------------------
*"*"Local Interface:
*"  IMPORTING
*"     REFERENCE(IM_FUNID) LIKE  ZMWHIIBTFTP01-FUNID
*"     REFERENCE(IM_FILENAME) LIKE  RLGRAP-FILENAME
*"     REFERENCE(IM_RFCDEST) LIKE  RFCDES-RFCDEST DEFAULT 'SAPFTPA'
*"     REFERENCE(IM_FLG_ADD) TYPE  XFLAG OPTIONAL
*"  TABLES
*"      TEXT OPTIONAL
*"  EXCEPTIONS
*"      NO_FUNCTION_ID
*"      NOT_CONNECTED
*"      FTP_PATH_ERROR
*"      NOT_FTP_DATA
*"----------------------------------------------------------------------

  CONSTANTS: c_key TYPE i VALUE 26101957."密钥
  "SAPFTPA:表示以SAP服务器为目的地,上传与下载都会放在SAP服务器上;SAPFTP:以Client端为目的地
  CONSTANTS: c_rfcdest LIKE rfcdes-rfcdest VALUE 'SAPFTPA'.
  DATA: flg_noftp TYPE c.
  DATA:g_pwd TYPE xuncode .
  DATA:g_error,
       g_str(99),
       g_slen TYPE i,
       g_hdl TYPE i,
       g_cmd(120).
  DATA:i_result   TYPE TABLE OF text WITH HEADER LINE.
  DATA:l_file TYPE char128.

  CLEAR flg_noftp.

* temp file name 用户名 日期 时间 传入的文件名
  CONCATENATE sy-uname sy-datum sy-uzeit im_filename  INTO l_file.

* 从自定义表中读取(IP,user,pssword)
  CLEAR: zmwhiibtftp01,zmwhiibtftp02.
  SELECT SINGLE
    zmwhiibtftp02~ftpip
    zmwhiibtftp02~usrnm
    zmwhiibtftp02~passwd
    zmwhiibtftp02~filepathf
    zmwhiibtftp02~filepaths
    INTO
    (zmwhiibtftp02-ftpip,
    zmwhiibtftp02-usrnm,
    zmwhiibtftp02-passwd,
    zmwhiibtftp02-filepathf,"FTP服务器目录
    zmwhiibtftp02-filepaths"SAP服务器或Client端目录
    )
    FROM zmwhiibtftp01 INNER JOIN zmwhiibtftp02
      ON zmwhiibtftp02~funid = zmwhiibtftp01~funid
    WHERE zmwhiibtftp01~funid = im_funid."根据 funcid 联合查询
  IF sy-subrc <> 0.
    RAISE no_function_id.
  ENDIF.

* 将密码转化为SAP的格式
  g_slen = STRLEN( zmwhiibtftp02-passwd ).
  CALL FUNCTION 'HTTP_SCRAMBLE'
    EXPORTING
      SOURCE      = zmwhiibtftp02-passwd
      sourcelen   = g_slen
      key         = c_key
    IMPORTING
      destination = g_pwd."加密密码
  CALL FUNCTION 'FTP_CONNECT'
    EXPORTING
      user            = zmwhiibtftp02-usrnm
      password        = g_pwd
      host            = zmwhiibtftp02-ftpip
      rfc_destination = c_rfcdest
    IMPORTING
      handle          = g_hdl
    EXCEPTIONS
      not_connected   = 1.
  IF sy-subrc <> 0.
    RAISE not_connected.
  ENDIF.

* 进入指定的FTP服务器目录
  CLEAR g_str.
  CONCATENATE 'cd' zmwhiibtftp02-filepathf INTO g_str SEPARATED BY space.
  CALL FUNCTION 'FTP_COMMAND'
    EXPORTING
      handle        = g_hdl
      command       = g_str
    TABLES
      data          = i_result
    EXCEPTIONS
      tcpip_error   = 1
      command_error = 2
      data_error    = 3.
  IF sy-subrc <> 0 .
    RAISE ftp_path_error.
  ENDIF.

* 进入到指定的SAP服务器上的目录
  IF zmwhiibtftp02-filepaths IS NOT INITIAL.
    CLEAR g_str.
    CONCATENATE 'lcd' zmwhiibtftp02-filepaths INTO g_str SEPARATED BY space.
    CALL FUNCTION 'FTP_COMMAND'
      EXPORTING
        handle        = g_hdl
        command       = g_str
      TABLES
        data          = i_result
      EXCEPTIONS
        tcpip_error   = 1
        command_error = 2
        data_error    = 3.
    IF sy-subrc <> 0 .
      RAISE ftp_path_error.
    ENDIF.
  ENDIF.

* get ftp file to sap server as temp file if file exist and in append mode
* 如果FTP服务器上有存在 im_filename 文件,则取到SAP服务器上并以l_file为临时文件名
  IF im_flg_add = 'X'.
    CLEAR g_str.
    CONCATENATE 'get'  im_filename l_file  INTO g_str SEPARATED BY space.
    CONDENSE g_str.
    CALL FUNCTION 'FTP_COMMAND'
      EXPORTING
        handle        = g_hdl
        command       = g_str
      TABLES
        data          = i_result
      EXCEPTIONS
        tcpip_error   = 1
        command_error = 2
        data_error    = 3.
  ENDIF.

* internal table data to sap server by dataset
* 将内表中的数据 APPEND 到SAP服务器上的临时文件上
  OPEN DATASET l_file FOR APPENDING IN LEGACY TEXT MODE CODE PAGE '8400' WITH WINDOWS LINEFEED
  IGNORING CONVERSION ERRORS. "S20090224085328
  IF sy-subrc = 0.
    LOOP AT text.
      TRANSFER text TO l_file.
    ENDLOOP.
    CLOSE DATASET l_file .
  ENDIF.
**********
* 实际上可以使用 FTP_R3_TO_SERVER: 直接将SAP的内表数据传输到其他系统,而不用先在
* SAP服务器或Client上生成临时文件
**********
* put sap server file to ftp server by ftp command
* 将SAP服务器止的临时文件l_file通过FTP上传到FTP服务器上并以im_filename文件名存储
  CLEAR g_str.
**{modi by zhengjun S20120217100617
*  CONCATENATE 'put'   l_file  im_filename INTO g_str SEPARATED BY space.
  concatenate 'put "' l_file  '" "' im_filename '"' into g_str .
**}
  CONDENSE g_str.
  CALL FUNCTION 'FTP_COMMAND'
    EXPORTING
      handle        = g_hdl
      command       = g_str
    TABLES
      data          = i_result
    EXCEPTIONS
      tcpip_error   = 1
      command_error = 2
      data_error    = 3.
  IF sy-subrc <> 0 .
    flg_noftp = 'X'.
  ENDIF.
* delete sap server temp file.
* 删除SAP服务器上生成的临时文件
  DELETE DATASET l_file.
  IF  flg_noftp = 'X'.
    RAISE not_ftp_data.
  ENDIF.

* quit ftp
* 退出FTP 服务
  CLEAR g_str.
  g_str = 'quit'.
  CONDENSE g_str.
  CALL FUNCTION 'FTP_COMMAND'
    EXPORTING
      handle        = g_hdl
      command       = g_str
    TABLES
      data          = i_result
    EXCEPTIONS
      tcpip_error   = 1
      command_error = 2
      data_error    = 3.

* disconnect
* 关闭SAP与其他系统的连接
  CALL FUNCTION 'FTP_DISCONNECT'
    EXPORTING
      handle = g_hdl.

*关闭SAP与其他系统的RFC连接.
  CALL FUNCTION 'RFC_CONNECTION_CLOSE'
    EXPORTING
      destination = c_rfcdest
    EXCEPTIONS
      OTHERS      = 1.

ENDFUNCTION.

使用zmm_data_to_ftp

types: line(1800) .
    data: txt type standard table of line with header line.

data: l_funid like zmwhiibtftp01-funid .
    data: l_filename like  rlgrap-filename.

    l_filename =  p_file.
    select single funid into l_funid from zmwhiibtftp01
    where funsk = p_funsk.
    call function 'ZMM_DATA_TO_FTP'
      exporting
        im_funid       = l_funid
        im_filename    = l_filename
        im_rfcdest     = 'SAPFTPA'
      tables
        text           = txt
      exceptions
        no_function_id = 1
        not_connected  = 2
        ftp_path_error = 3
        not_ftp_data   = 4
        others         = 5.

20.4.     文件读写

.
    WRITE: / wa-carrid,
             wa-connid,
             wa-countryfr,
             wa-cityfrom,
             wa-cityto,
             wa-fltime,
             wa-distance.
  ELSE.
    EXIT.
  ENDIF.
ENDDO.
CLOSE DATASET file.

[SAP ABAP开发技术总结]FTP到文件服务器,服务器上文件读写的更多相关文章

  1. ABAP开发顾问必备:SAP ABAP开发技术总结

    声明:原创作品,转载时请注明文章来自SAP师太技术博客( 博/客/园www.cnblogs.com):www.cnblogs.com/jiangzhengjun,并以超链接形式标明文章原始出处,否则将 ...

  2. [SAP ABAP开发技术总结]OPEN SQL

    声明:原创作品,转载时请注明文章来自SAP师太技术博客( 博/客/园www.cnblogs.com):www.cnblogs.com/jiangzhengjun,并以超链接形式标明文章原始出处,否则将 ...

  3. [SAP ABAP开发技术总结]内表操作

    声明:原创作品,转载时请注明文章来自SAP师太技术博客( 博/客/园www.cnblogs.com):www.cnblogs.com/jiangzhengjun,并以超链接形式标明文章原始出处,否则将 ...

  4. ABAP开发顾问必备:SAP ABAP开发技术总结[转载]

    转载自SAP师太技术博客,原文链接:http://www.cnblogs.com/jiangzhengjun/p/4260224.html 在原文上增加了链接,此文及此文的链接版权都归SAP师太所有. ...

  5. [SAP ABAP开发技术总结]ABAP程序之间数据共享与传递

    声明:原创作品,转载时请注明文章来自SAP师太技术博客( 博/客/园www.cnblogs.com):www.cnblogs.com/jiangzhengjun,并以超链接形式标明文章原始出处,否则将 ...

  6. [SAP ABAP开发技术总结]IDoc

    声明:原创作品,转载时请注明文章来自SAP师太技术博客( 博/客/园www.cnblogs.com):www.cnblogs.com/jiangzhengjun,并以超链接形式标明文章原始出处,否则将 ...

  7. [SAP ABAP开发技术总结]字符串处理函数、正则表达式

    声明:原创作品,转载时请注明文章来自SAP师太技术博客( 博/客/园www.cnblogs.com):www.cnblogs.com/jiangzhengjun,并以超链接形式标明文章原始出处,否则将 ...

  8. [SAP ABAP开发技术总结]ALV

    声明:原创作品,转载时请注明文章来自SAP师太技术博客( 博/客/园www.cnblogs.com):www.cnblogs.com/jiangzhengjun,并以超链接形式标明文章原始出处,否则将 ...

  9. [SAP ABAP开发技术总结]面向对象OO

    声明:原创作品,转载时请注明文章来自SAP师太技术博客( 博/客/园www.cnblogs.com):www.cnblogs.com/jiangzhengjun,并以超链接形式标明文章原始出处,否则将 ...

随机推荐

  1. Hadoop实战2:MapReduce编程-WordCount实例-streaming-python环境

    这是搭建hadoop环境后的第一个MapReduce程序: 基于hadoop streaming的python的脚本: 1 map.py文件,把文本的内容划分成单词: #!/usr/bin/pytho ...

  2. sql多表查询(out join,inner join, left join, right join)

    left join以左表为基准显示所有左表的信息,在on中有符合条件的其他表也显示出来 right join则相反 inner join的只显示on中符合条件的 1 使用多个表格 在「world」资料 ...

  3. JavaSPI机制学习笔记

    最近在阅读框架源代码时,常常看到 SPI 的子包, 忍不住查了下: Service Provider Interface : 服务提供接口. JavaSPI 实际上是“基于接口的编程+策略模式+配置文 ...

  4. jQuery上传插件,文件上传测试用例

    jQuery上传插件,文件上传测试用例 jQuery File Upload-jQuery上传插件介绍http://www.jq22.com/jquery-info230 jQuery File Up ...

  5. TI CC2541的整体目标

    1. App端会发送一定数量的byte过来蓝牙, 每2个byte是一个汉字的编码. 2. 拿到汉字编码之后, 统计字符数量, 然后通过SPI, 搜索编码 3. 收到的编码, 每个汉字字符有32个byt ...

  6. java几道简单的面试题目

    1.   请问以下程序会输出什么? public   class   Test   {  public   static   void   main(String[]   args)   {  Par ...

  7. 模数转换器(ADC)的基本原理【转】

    模数转换器(ADC)的基本原理 模拟信号转换为数字信号,一般分为四个步骤进行,即取样.保持.量化和编码.前两个步骤在取样-保持电路中完成,后两步骤则在ADC中完成. 常用的ADC有积分型.逐次逼近型. ...

  8. Oracle主库归档丢失,备库日志有gap,在不重建备库的情况下,恢复备库

    本文主要描述Oracle备库日志与主库日志之间有gap,切主库这部分gap的归档日志已经删除或丢失,如何在不重建备库的情况下,恢复备库. 欢迎转载,请注明作者.出处. 作者:张正 blog:http: ...

  9. NIOS II CPU复位异常的原因及解决方案

    NIOS II CPU复位异常的原因及解决方案   近期在用nios ii做项目时,发现一个奇怪的现象,在NIOS II EDS软件中编写好的代码,烧写到芯片中,第一次能够正常运行,但是当我按下板卡上 ...

  10. greenplum集群安装

    一.环境配置 1.地址分配 192.168.1.201 mdw master 192.168.1.202 sdw1 segment1 192.168.1.203 sdw2 segment2 2.创建用 ...