混淆编译造成 java.lang.UnsatisfiedLinkError: JNI_ERR returned from JNI_OnLoad in “/data/app-lib/xx/xx.so”

android app运行的时候偶尔会遇到加载so文件的问题,譬如 java.lang.UnsatisfiedLinkError: JNI_ERR returned from JNI_OnLoad in "/data/app-lib/xxx/xxx.so"

今天遇到这种问题时,我按照网上的资料进行如下检查:

  1. 检查对应编译目录lib下有没有对应so文件;
  2. 检查对应module下的 build.gradle 没有如下条件
    
    sourceSets {
        main {
            jniLibs.srcDirs = ['libs']
        }
    }
    

我代码里上面1,2条件都满足,但仍然会有如题的exception。

捣鼓半天到最后才发现是混淆的问题,就是加载so文件的java代码被混淆了,导致加载时的文件的名字被改动了,没有加载到正确的so文件。

所以上面的检查步骤我觉得还应再加上一条:

3. 如果是“允许混淆"的"release"编译模式下,需要检查”加载so文件的java目录“是否加入混淆文件“proguard-rules.pro,  譬如

-keep class tv.xxx.player.**  { *; }

我今天的so加载问题就是在混淆proguard-rules.pro文件中加入对应的java文件就解决了


版权声明:本文为kuanxu原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。