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包,若有需要可以联系本人获取。