• 20170401 ABAP调用CIS webservice


    问题:

    SAP  abap

    SRM java  调webservice 不通,

    CIS java  这边的webservice 可以通,

    WHY?

    key:
    请求头,
    系统框架的问题,

    LF:因为请求头的问题吧
    CX:请求头有什么差别? 

    LF:r3发出来的请求,header里面很复杂 ;大概不符合srm的要求,
            这个最开始是 波哥调某个系统的时候出现的,
     
     我搞不清楚为啥会出现,而且其他sap开发人员做接口不会出现这个问题吗,之前一直想找到原因,但还是因为不够执著,且能力也有欠缺未能成功find reason ,
     可能是某些系统框架的问题,
     

    abap 《-》java 还是听便利的,从技术角度很多都可行,

     

    FUNCTION ZMLSCP1_FR0008.
    *"----------------------------------------------------------------------
    *"*"本地接口:
    *"  IMPORTING
    *"     VALUE(I_EBELN) TYPE  EBELN OPTIONAL
    *"     VALUE(I_MATNR) TYPE  MATNR OPTIONAL
    *"  EXPORTING
    *"     VALUE(O_STATU) TYPE  CHAR1
    *"     VALUE(O_MSG) TYPE  CHAR255
    *"  TABLES
    *"      OT_RESOURCE STRUCTURE  ZSRM_RESOURCE
    *"----------------------------------------------------------------------
    *&Flag  0-手动; 1-自动
      DATA:L_TABIX TYPE SY-TABIX.
      DATA:LV_FLAG TYPE C.
      DATA:LV_CON  TYPE STRING.
      DATA: ERROR TYPE REF TO CX_AI_SYSTEM_FAULT.
      DATA: PRXY  TYPE REF TO ZCO_REQUEST_IMATNR_RESOURCE_SE."Proxy Name
      DATA: Z_IN  TYPE ZREQUEST8. "request in
      DATA: Z_OUT TYPE ZRESPONSE8."request out
      DATA: O_CX  TYPE  REF  TO  CX_ROOT.
      DATA: O_ERROR TYPE REF TO CX_ST_ERROR.
      TYPES:BEGIN OF TY_RE,
        BACKUP1 TYPE STRING,"备用字段1
        BACKUP2 TYPE STRING,"备用字段2
        BACKUP3 TYPE STRING,"备用字段3
        BACKUP4 TYPE STRING,"备用字段4
        BACKUP5 TYPE STRING,"备用字段5
        EBELN   TYPE STRING,"采购订单号
        EBELP   TYPE STRING,"采购订单行项目号
        LIFNRAMOUNT TYPE STRING, "供应商库存数量
        MAKTX   TYPE STRING,     "物料描述
        MATNR   TYPE STRING,     "物料代码
        PROAMOUNT TYPE STRING,   "生产数量
        STOREAMOUNT TYPE STRING, "线边仓库存数量
    *    PRODATE TYPE DATUM,     "生产日期
            END OF TY_RE.
      DATA:GT_RE TYPE STANDARD TABLE OF TY_RE,
           WA_RE LIKE LINE OF GT_RE.
    
    
    *&job user
      IF SY-UNAME EQ ''.
        LV_FLAG = '1'.
      ELSE.
        LV_FLAG = '0'.
      ENDIF.
    
      CONCATENATE '<in0>' LV_FLAG '</in0>' '<in1>' I_EBELN '</in1>' '<in2>' I_MATNR '</in2>' INTO LV_CON.
    
    *&s1.call proxy get data via cis
    *  Z_IN-REQUEST_DATA = '<?xml version="1.0" encoding="UTF-8"?><handleIMatnrResourceService><in0>' && LV_FLAG && '</in0></handleIMatnrResourceService>'.
      CONCATENATE '<?xml version="1.0" encoding="UTF-8"?><handleIMatnrResourceService>' LV_CON '</handleIMatnrResourceService>' INTO Z_IN-REQUEST_DATA.
      CLEAR ERROR.
      TRY.
          CREATE OBJECT PRXY
            EXPORTING
              LOGICAL_PORT_NAME = 'ZMLSCP_GET_RESOURCE'.
          CALL METHOD PRXY->REQUEST
            EXPORTING
              INPUT  = Z_IN
            IMPORTING
              OUTPUT = Z_OUT.
        CATCH CX_AI_SYSTEM_FAULT INTO ERROR.
          O_STATU = 'E'.
          O_MSG = ERROR->ERRORTEXT.
          RETURN.
      ENDTRY.
    
    *&1.1 is it ok?
      IF Z_OUT-RETURN_CODE = 'E'.
        O_STATU = 'E'.
        O_MSG = Z_OUT-RETURN_DESC.
    *    RETURN.
      ENDIF.
    
    *  for test:
      IF Z_OUT-RETURN_DATA IS INITIAL.
        CONCATENATE
        '<?xml version="1.0" encoding="UTF-8"?>'
    
        '<handleIMatnrResourceServiceResponse><out>'
        '<MLMatnrResource><backup1/><backup2/><backup3/><backup4/><backup5/><ebeln>4800064316</ebeln><ebelp>00010</ebelp><lifnrAmount/><maktx>A级冰箱型号标贴_C0414.6-1(A</maktx>'
        '<matnr>000000000800013563</matnr><proAmount/><storeAmount>12.0</storeAmount></MLMatnrResource>'
    
        '<MLMatnrResource><backup1/><backup2/><backup3/><backup4/><backup5/><ebeln>4800064316</ebeln><ebelp>00020</ebelp><lifnrAmount/><maktx>A级冰箱型号标贴_C0414.6-1(A</maktx>'
        '<matnr>000000000800013563</matnr><proAmount/><storeAmount>12.0</storeAmount></MLMatnrResource>'
    
        '<MLMatnrResource><backup1/><backup2/><backup3/><backup4/><backup5/><ebeln>4800064317</ebeln><ebelp>00010</ebelp><lifnrAmount/><maktx>A级冰箱型号标贴_C0414.6-1(A</maktx>'
        '<matnr>000000000800013563</matnr><proAmount/><storeAmount>12.0</storeAmount></MLMatnrResource>'
    
        '</out></handleIMatnrResourceServiceResponse>' INTO Z_OUT-RETURN_DATA .
      ENDIF.
    *&s2.transfer XML
      IF Z_OUT-RETURN_DATA IS NOT INITIAL."业务系统返回报文不为空
        TRY .
            CLEAR:GT_RE,WA_RE.
            CALL TRANSFORMATION  ZML_XML_TRANS02"ZML_XML_RESOURCE
            SOURCE XML Z_OUT-RETURN_DATA
            RESULT MLMATNRRESOURCE =  GT_RE."OT_RESOURCE[]
            IF  SY-SUBRC NE 0.
              O_STATU = 'E'.
              O_MSG = 'XML解析失败!'.
              RETURN.
            ENDIF.
          CATCH CX_ST_ERROR INTO O_ERROR .
            O_STATU = 'E'.
            O_MSG = O_ERROR->GET_TEXT( ) .
        ENDTRY.
      ELSE.
        O_STATU = 'E'.
        O_MSG = '返回结果为空!'.
      ENDIF.
    
    
    *&s3.data save to ZSRM_RESOURCE
        LOOP AT GT_RE INTO WA_RE.
          MOVE-CORRESPONDING WA_RE TO OT_RESOURCE.
          OT_RESOURCE-ZDATUM = SY-DATUM.
          OT_RESOURCE-ZCPUTM = SY-UZEIT.
          OT_RESOURCE-USNAM  = SY-UNAME.
          OT_RESOURCE-ZFLAG  = LV_FLAG.
          APPEND OT_RESOURCE.
    * MODIFY GT_RE FROM WA_RE.
    * CLEAR WA_RE.
        ENDLOOP.
    * TRY
        CHECK OT_RESOURCE[] IS NOT INITIAL.
        MODIFY ZSRM_RESOURCE FROM TABLE OT_RESOURCE.
        IF SY-SUBRC EQ 0.
          COMMIT WORK AND WAIT .
          DESCRIBE TABLE OT_RESOURCE LINES L_TABIX.
          O_STATU = 'S'.
          O_MSG   = '成功存入ZSRM_RESOURCE' && L_TABIX && '条记录!'.
        ELSE.
          ROLLBACK WORK.
          O_STATU = 'E'.
          O_MSG   = '数据存入 ZSRM_RESOURCE表失败!'.
        ENDIF.
    
    
    
    
    ENDFUNCTION.
  • 相关阅读:
    Ubuntu 下安装 PHP Solr 扩展的安装与使用
    转载:Ubuntu14-04安装redis和php5-redis扩展
    Datagridview全选,更新数据源代码
    sftp不识别的问题ssh命令找不到
    linux:如何修改用户的密码
    win7.wifi热点
    Rico Board.1.环境配置
    linux学习记录.6.vscode调试c makefile
    linux学习记录.5.git & github
    linux学习记录.3.virtualbox 共享文件夹
  • 原文地址:https://www.cnblogs.com/rainysblog/p/6655251.html
Copyright © 2020-2023  润新知