【SAP Abap】JAVA代码访问SAP RFC

1、准备一个rfc函数

登录SAP SE37,编写一个简单的二元计算器函数

FUNCTION ZLL_FM_DEMO03.
*"----------------------------------------------------------------------
*"*"本地接口:
*"  IMPORTING
*"     VALUE(P1) TYPE  INT4 DEFAULT 0
*"     VALUE(P2) TYPE  INT4 DEFAULT 0
*"     VALUE(OPERATOR) TYPE  CHAR1 DEFAULT '+'
*"  EXPORTING
*"     VALUE(RESULT) TYPE  INT4
*"     VALUE(MSG) TYPE  CHAR255
*"----------------------------------------------------------------------
DATA:err_text TYPE string,
       e TYPE REF TO cx_root.
  TRY.
    CASE operator.
      WHEN '+'.       result = p1 + p2.
      WHEN '-'.       result = p1 - p2.
      WHEN '*'.       result = p1 * p2.
      WHEN '/'.       result = p1 / p2.
      WHEN OTHERS.
        CONCATENATE '操作符' operator ',SAP无法识别' into msg.
    ENDCASE.
    CATCH cx_root INTO e.
      err_text = e->get_text( ).
      msg = err_text.
  ENDTRY.
ENDFUNCTION.

备注:该RFC需要设置成允许远程访问,如下图所示。
在这里插入图片描述

2、java访问rfc

2.1、创建JAVA项目HelloJava,添加对sapjco3.jar的引用,如下图
在这里插入图片描述

2.2、添加一个java类,访问SAP的方法类,SAPConn.java

package com.zll.test;

import java.io.File;
import java.io.FileOutputStream;
import java.util.Properties;

import com.sap.conn.jco.JCoDestination;
import com.sap.conn.jco.JCoDestinationManager;
import com.sap.conn.jco.JCoException;
import com.sap.conn.jco.ext.DestinationDataProvider;

/**
 * 与SAP连接配置
 * 
 * @author jay
 */
public class SAPConn {
    private static final String ABAP_AS_POOLED = "ABAP_AS_WITH_POOL";
    
    static {
        Properties connectProperties = new Properties();
        connectProperties.setProperty(DestinationDataProvider.JCO_ASHOST, "1xx.1x.x.xxx");// 服务器
        connectProperties.setProperty(DestinationDataProvider.JCO_SAPROUTER, "/H/1xx.xx.xxx.xx/S/3299/H/");// 路由
        connectProperties.setProperty(DestinationDataProvider.JCO_SYSNR, "xx"); // 系统编号
        connectProperties.setProperty(DestinationDataProvider.JCO_CLIENT, "xxx"); // SAP集团
        connectProperties.setProperty(DestinationDataProvider.JCO_USER, "xxxx"); // SAP用户名
        connectProperties.setProperty(DestinationDataProvider.JCO_PASSWD, "xxxx"); // 密码
        connectProperties.setProperty(DestinationDataProvider.JCO_LANG, "ZH"); // 登录语言:ZH EN
        connectProperties.setProperty(DestinationDataProvider.JCO_POOL_CAPACITY, "3"); // 最大连接数
        connectProperties.setProperty(DestinationDataProvider.JCO_PEAK_LIMIT, "10"); // 最大连接线程

        createDataFile(ABAP_AS_POOLED, "jcoDestination", connectProperties);
    }

    /**
	* 创建SAP接口属性文件。
	* @param name
	* ABAP管道名称
	* @param suffix
	 * 属性文件后缀
	* @param properties
	*   属性文件内容
     */
    private static void createDataFile(String name, String suffix, Properties properties) {
        File cfg = new File(name + "." + suffix);
        if (cfg.exists()) {
            cfg.deleteOnExit();
        }
        try {
            FileOutputStream fos = new FileOutputStream(cfg, false);
            properties.store(fos, "for tests only !");
            fos.close();
        } catch (Exception e) {
            System.out.println("Create Data file fault, error msg: " + e.toString());
            throw new RuntimeException("Unable to create the destination file " + cfg.getName(), e);
        }
    }

    /*
     * * 获取SAP连接
     * 
     * @return SAP连接对象
     */
    public static JCoDestination connect(String client) {
        JCoDestination destination = null;
        try {
            destination = JCoDestinationManager.getDestination(ABAP_AS_POOLED);
        } catch (JCoException e) {
            System.out.println("Connect SAP fault, error msg: " + e.toString());
        }
        return destination;
    }
    
    public static JCoDestination connect() {
        return connect("");
    }
}

2.3、添加一个java类,包含main方法,HelloSAPRFC.java

package com.zll.test;

import com.sap.conn.jco.JCoDestination;
import com.sap.conn.jco.JCoFunction;
import com.sap.conn.jco.JCoParameterList;

public class HelloSAPRFC {
	public static void main(String[] args) {
		
        JCoFunction function = null;
        JCoDestination destination = SAPConn.connect();
        int result=0;//调用接口返回状态
        String message="";//调用接口返回信息
        
        try {
            //设置调用函数:ZLL_FM_DEMO03
            function = destination.getRepository().getFunction("ZLL_FM_DEMO03");
            //设置传入参数
            JCoParameterList input = function.getImportParameterList();
            input.setValue("P1", 10);
            input.setValue("P2", 3);
            input.setValue("OPERATOR", "+"); // 输入参数
            //执行函数
            function.execute(destination);
            //解析传出数据
            JCoParameterList output = function.getExportParameterList();
            result= output.getInt("RESULT");//调用接口返回结果
            message= output.getString("MSG");//调用接口返回信息 
            
            System.out.println("调用返回结果(和)--->"+result+";\n调用返回状态--->"+message);
        }catch (Exception e) {
            e.printStackTrace();
        }
    }
}

3、测试运行

调用返回结果(和)--->13;
调用返回状态--->

访问成功,获取计算结果。

4、说明

文中涉及的 jar包,若有需要可以联系本人获取。

  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值