SAP Java Connector 组件介绍

54 篇文章 0 订阅
SAPJavaConnector3.1的运行时包括sapjco3.jar和JNI库。当应用首次引用JCo类时,类加载器加载并执行静态初始化,按特定顺序查找并加载JNI库。找不到或加载错误会导致UnsatisfiedLinkError,可能原因包括库位置错误、版本过旧、权限问题、位宽不匹配或不兼容的操作系统版本。
摘要由CSDN通过智能技术生成

SAP Java Connector 3.1 运行时环境由两部分组成:

  1. sapjco3.jar - 包含 JCo 的 Java 运行时类的存档
  2. {library prefix}sapjco3{shared library extension} - 包含 JCo 原生代码的 JNI 库

JCo 的 JNI 库包含用于网络通信的本机代码。 JCo 存档和 JNI 库之间只有松散的耦合,但是 JCo 需要 JNI 库的特定最低版本,该版本通常与分发包中的 JCo 存档一起提供。

注意:如果开发人员使用的是 32 位 JVM,则还需要 32 位 JCo JNI 库,无论是在 32 位还是 64 位操作系统上运行都是如此。

运行时初始化逻辑

当应用程序第一次引用 JCo 类时,它会被关联的类加载器(class loader)加载。

在此过程中,将执行 JCo 的静态初始化程序。该例程将使用以下算法搜索并加载 JCo JNI 库:

  1. 尝试从 sapjco3.jar 文件所在的同一目录加载 sapjco3 JNI 库。

  2. 尝试从 sapjco3.jar 文件所在的平台相关子目录加载 sapjco3 JNI 库。适当的 JNI 库加载路径是通过考虑当前使用的操作系统和 JVM 运行时环境来确定的,并引用以下子目录之一:

ntamd64,ntintel,linuxx86_64,linuxppc64le,linuxs390x,darwinintel64,rs6000_64,hpia64,sunx86_64,sun_64,os390_64,as400_pase_64

  1. 沿着 java.library.path 系统属性中定义的目录路径从左到右搜索 sapjco3 JNI 库,如果找到则从那里加载它。
    注意:如果不手动设置该属性,JVM 通常会在启动时将 OS 特定的库路径环境变量设置为默认的 java.library.path 系统属性。

  2. 通过将此任务委托给它的 System.loadLibrary(String libname) 方法,让 JVM 处理 sapjco3 JNI 库的加载。

如果找不到或无法加载 sapjco3 JNI 库,您将收到 UnsatisfiedLinkError 错误,其中包含操作系统提供的详细信息。

此错误消息可能由以下原因之一引起:

  • 使用上述算法无法找到 sapjco3 JNI 库,因为您无意中将其安装到了错误的目录,或者忘记在操作系统特定的库路径环境变量或 java.library.path 系统属性中指定其目录。
  • 找到的 sapjco3 JNI 库版本太旧。
  • 发现的 sapjco3 JNI 库缺少执行权限标志。
  • 找到的 sapjco3 JNI 库的位宽与 JVM 不同(32 位与 64 位)。
  • 找到的 sapjco3 JNI 库来自不同的 JCo 发行版,不适用于您的操作系统和/或硬件处理器。
  • 找到的 sapjco3 JNI 库需要更高的操作系统版本。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值