【问题标题】:Android: Unable to load pjsua2 while using Opus lib with itAndroid:使用 Opus lib 时无法加载 pjsua2
【发布时间】:2017-04-26 03:05:47
【问题描述】:

我在我的 android 项目中使用 PJSIP,它运行良好。现在,我需要在我的项目中添加 Opus-Android 库。代码编译得很好,但是在启动应用程序时会出现问题。它给了我以下例外:

ava.lang.UnsatisfiedLinkError: dalvik.system.PathClassLoader[DexPathList[[zip file "/data/app/com.matsoltech.android.chatellite-1/base.apk", zip file "/data/app/com.matsoltech.android.chatellite-1/split_lib_dependencies_apk.apk", zip file "/data/app/com.matsoltech.android.chatellite-1/split_lib_slice_0_apk.apk", zip file "/data/app/com.matsoltech.android.chatellite-1/split_lib_slice_1_apk.apk", zip file "/data/app/com.matsoltech.android.chatellite-1/split_lib_slice_2_apk.apk", zip file "/data/app/com.matsoltech.android.chatellite-1/split_lib_slice_3_apk.apk", zip file "/data/app/com.matsoltech.android.chatellite-1/split_lib_slice_4_apk.apk", zip file "/data/app/com.matsoltech.android.chatellite-1/split_lib_slice_5_apk.apk", zip file "/data/app/com.matsoltech.android.chatellite-1/split_lib_slice_6_apk.apk", zip file "/data/app/com.matsoltech.android.chatellite-1/split_lib_slice_7_apk.apk", zip file "/data/app/com.matsoltech.android.chatellite-1/split_lib_slice_8_apk.apk", zip file "/data/app/com.matsoltech.android.chatellite-1/split_lib_slice_9_apk.apk"],nativeLibraryDirectories=[/data/app/com.matsoltech.android.chatellite-1/lib/arm64, /data/app/com.matsoltech.android.chatellite-1/base.apk!/lib/arm64-v8a, /data/app/com.matsoltech.android.chatellite-1/split_lib_dependencies_apk.apk!/lib/arm64-v8a, /data/app/com.matsoltech.android.chatellite-1/split_lib_slice_0_apk.apk!/lib/arm64-v8a, /data/app/com.matsoltech.android.chatellite-1/split_lib_slice_1_apk.apk!/lib/arm64-v8a, /data/app/com.matsoltech.android.chatellite-1/split_lib_slice_2_apk.apk!/lib/arm64-v8a, /data/app/com.matsoltech.android.chatellite-1/split_lib_slice_3_apk.apk!/lib/arm64-v8a, /data/app/com.matsoltech.android.chatellite-1/split_lib_slice_4_apk.apk!/lib/arm64-v8a, /data/app/com.matsoltech.android.chatellite-1/split_lib_slice_5_apk.apk!/lib/arm64-v8a, /data/app/com.matsoltech.android.chatellite-1/split_lib_slice_6_apk.apk!/lib/arm64-v8a, /data/app/com.matsoltech.android.chatellite-1/split_lib_slice_7_apk.apk!/lib/arm64-v8a, /data/app/com.matsoltech.android.chatellite-1/split_lib_slice_8_apk.apk!/lib/arm64-v8a, /data/app/com.matsoltech.android.chatellite-1/split_lib_slice_9_apk.apk!/lib/arm64-v8a, /system/lib64, /vendor/lib64]]] couldn't find "libpjsua2.so"
                                                                         at java.lang.Runtime.loadLibrary0(Runtime.java:984)
                                                                         at java.lang.System.loadLibrary(System.java:1530)
                                                                         at com.matsoltech.android.chatellite.utils.pjsua_utils.MyApp.<clinit>(MyApp.java:51)
                                                                         at com.matsoltech.android.chatellite.utils.service.MainService.setupPJSUA(MainService.java:99)
                                                                         at com.matsoltech.android.chatellite.utils.service.MainService.onStartCommand(MainService.java:90)
                                                                         at android.app.ActivityThread.handleServiceArgs(ActivityThread.java:3326)
                                                                         at android.app.ActivityThread.-wrap21(ActivityThread.java)
                                                                         at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1582)
                                                                         at android.os.Handler.dispatchMessage(Handler.java:102)
                                                                         at android.os.Looper.loop(Looper.java:154)
                                                                         at android.app.ActivityThread.main(ActivityThread.java:6119)
                                                                         at java.lang.reflect.Method.invoke(Native Method)
                                                                         at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:886)
                                                                         at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:776)

一旦我从 gradle 中删除 Opus,pjsip 库就会开始正常工作。

这是我的依赖项:

dependencies {
compile fileTree(dir: 'libs', include: ['*.jar'])
androidTestCompile('com.android.support.test.espresso:espresso-core:2.2.2', {
    exclude group: 'com.android.support', module: 'support-annotations'
})

compile 'com.android.support:appcompat-v7:25.2.0'
compile 'com.android.support:design:25.2.0'
compile 'com.android.support:support-v4:25.2.0'
compile 'ch.acra:acra:4.9.0'
compile 'org.java-websocket:Java-WebSocket:1.3.0'
compile 'top.oply.opuslib:opuslib:1.0.2'
testCompile 'junit:junit:4.12'
}

我的应用程序的 gradle:

compileSdkVersion 25
    buildToolsVersion "25.0.2"

    defaultConfig {
        applicationId "com.matsoltech.android.chatellite"
        minSdkVersion 11
        targetSdkVersion 25
        versionCode 1
        versionName code.toString()
        testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
        ndk {
            moduleName "libpjsua2"
        }
    }
    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        }

        debug {
            jniDebuggable true
        }

    }

而抛出的异常在这里:

static {

    System.loadLibrary("pjsua2");
    System.out.println("Library loaded");
}

那么,我哪里做错了?

【问题讨论】:

    标签: android pjsip opus


    【解决方案1】:

    你需要这个,然后你的代码应该可以工作。

    项目编译

    pre-requisites
    
    JDK v1.8 or higher
    SDK v2.2.1 or higher
    NDK r10d or higher (Note: remember to export NDK's path)
    Android Studio (with SDK) 1.2.1 or higher
    

    【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2013-03-02
    • 2021-12-07
    • 1970-01-01
    • 1970-01-01
    • 2021-05-18
    • 1970-01-01
    • 1970-01-01
    • 2016-11-26
    相关资源
    最近更新 更多