10

我正在尝试将libsodium库集成到 Android 项目中。我正在使用带有 gradle (0.9) 和 android 构建工具 (19.1) 的 Android Studio (0.5.8)。我用可以在库中找到的脚本编译了 libsodium。我为不同的架构(arm、arm-v7a、mips 和 x86)获得了四个 preBuild 库(.so 文件)。我把这些文件放在 jniLibs 文件夹中。我在我的 build.gradle 文件中声明我正在使用 NDK 并在 local.properties 文件上配置路径。

在这个版本的 gradle 中,不需要编写 makefile ( http://ph0b.com/android-studio-gradle-and-ndk-integration/ )

在进行静态调用后,我在我的活动中声明了一些本机函数:

static {
    System.loadLibrary("sodium");
}

public final static native String sodium_version_string();

onCreate() {
    ...
    Log.d(getClass().getName(), "Sodium version:" + sodium_version_string());
}

Logcat 输出为:

05-29 23:14:10.538     481-1569/system_process I/ActivityManager﹕ Start proc com.example.myapplication2.app.x86 for activity com.example.myapplication2.app.x86/com.example.myapplication2.app.MainActivity: pid=1584 uid=10056 gids={50056, 1028}
05-29 23:14:10.554    1584-1584/com.example.myapplication2.app.x86 D/dalvikvm﹕ Trying to load lib /data/app-lib/com.example.myapplication2.app.x86-2/libsodium.so 0xa4ed8520
05-29 23:14:10.562    1584-1584/com.example.myapplication2.app.x86 D/dalvikvm﹕ Added shared lib /data/app-lib/com.example.myapplication2.app.x86-2/libsodium.so 0xa4ed8520
05-29 23:14:10.562    1584-1584/com.example.myapplication2.app.x86 D/dalvikvm﹕ No JNI_OnLoad found in /data/app-lib/com.example.myapplication2.app.x86-2/libsodium.so 0xa4ed8520, skipping init
05-29 23:14:10.578    1584-1584/com.example.myapplication2.app.x86 W/dalvikvm﹕ No implementation found for native Lcom/example/myapplication2/app/MainActivity;.sodium_version_string:()Ljava/lang/String;
05-29 23:14:10.578    1584-1584/com.example.myapplication2.app.x86 D/AndroidRuntime﹕ Shutting down VM
05-29 23:14:10.578    1584-1584/com.example.myapplication2.app.x86 W/dalvikvm﹕ threadid=1: thread exiting with uncaught exception (group=0xa4c46648)
05-29 23:14:10.578    1584-1584/com.example.myapplication2.app.x86 E/AndroidRuntime﹕ FATAL EXCEPTION: main
java.lang.UnsatisfiedLinkError: Native method not found: com.example.myapplication2.app.MainActivity.sodium_version_string:()Ljava/lang/String;
        at com.example.myapplication2.app.MainActivity.sodium_version_string(Native Method)
        at com.example.myapplication2.app.MainActivity.onCreate(MainActivity.java:28)

我是否错过在另一个文件中声明某些内容?真的有必要 kalium-JNI 吗?这个库如何包含在项目中?

谢谢。

4

1 回答 1

1

现在你的 Java 代码无法知道如何使用你的本地库。您需要使用 Kalium-JNI 或仅实现您需要的部分来完成 JNI 部分。

在 的情况下sodium_version_string(),这应该有效:

jstring java_com_example_myapplication2_app_MainActivity_sodium_version_string(JNIEnv* env, jclass cls)
{
    return (env*)->NewStringUTF(env, sodium_version_string());
}

感谢 JNI 约定,这里java_com_example_myapplication2_app_MainActivity_sodium_version_string的实现将自动关联到您。static native String sodium_version_string()

您可以JNI_Onload()改为手动声明此类关联,但您仍然需要处理实现中的 JNI 环境和对象。

于 2014-06-02T10:00:33.507 回答