Java jni 加载 so 失败,提示 Java .lang.UnsatisfiedLinkError: no xxx in Java .library.path

查看 12|回复 0
作者:wbd31   
项目中把 so 库文件放到了 jar 包里,在 static 代码块中调用如下代码加载 so 库
try (InputStream in = getResource(path)) {
    // 写入 jar classpath 里的 so 文件到外部临时文件
    File temp = new File(TEMP_DIR + name);
    FileUtils.copyInputStreamToFile(Objects.requireNonNull(in), temp);
    String absolutePath = temp.getAbsolutePath();
    Runtime.getRuntime().exec(new String[] {"/bin/chmod", "755", absolutePath});
    log.info("加载企业微信会话存档 SDK LIB 开始, {}", absolutePath);
    System.load(absolutePath);
    log.info("加载企业微信会话存档 SDK LIB 结束, {}", absolutePath);
} catch (Throwable e) {
    log.error("加载企业微信会话存档 SDK LIB, 异常", e);
}
整个方法没有报错,通过 pldd 命令查看也有 /tmp/libWeWorkFinanceSdk_Java.so 的输出
但是调用 native jni 方法的时候仍然报错 java.lang.UnsatisfiedLinkError: no WeWorkFinanceSdk_Java in java.library.path
后面通过设置环境变量 export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/tmp/ 却可以正常工作
这是什么问题 🤔
您需要登录后才可以回帖 登录 | 立即注册

返回顶部