TargetSdkVersion 为24时,找不到libsqlite.so,导致连上无法连接服务器。


            
2016-11-02 15:41 | Android

回答:

问题描述:

错误日志如下:11-02 03:33:12.533 4855-4855/? E/RongLog: [ RongExceptionHandler ] uncaughtException

  3   java.lang.UnsatisfiedLinkError: dlopen failed: library "libsqlite.so" not found

  4   at java.lang.Runtime.loadLibrary0(Runtime.java:977)

  5   at java.lang.System.loadLibrary(System.java:1530)

  6   at io.rong.imlib.NativeObject.<clinit>(NativeObject.java:8)

  7   at io.rong.imlib.NativeClient.init(NativeClient.java:133)

  8   at io.rong.imlib.LibHandlerStub.<init>(LibHandlerStub.java:46)

  9   at io.rong.imlib.ipc.RongService.onBind(RongService.java:31)

 10   at android.app.ActivityThread.handleBindService(ActivityThread.java:3189)

 11   at android.app.ActivityThread.-wrap3(ActivityThread.java)

 12   at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1555)

 13   at android.os.Handler.dispatchMessage(Handler.java:102)

 14   at android.os.Looper.loop(Looper.java:154)

 15   at android.app.ActivityThread.main(ActivityThread.java:6077)

 16   at java.lang.reflect.Method.invoke(Native Method)

 17   at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:865)


解答:

原因是7.0以后,Andorid不允许直接访问系统的私有so文件了。

两种解决方案:

  1. 把targetSdkVersion改小于24。

  2. apk中带上需要的so文件,这儿是libsqlite.so

    1. 下载附件中的so文件,放到对应的文件夹下,如libs/armv7-abi/libsqlite.so,并注意你的gradle是否引用了这个目录,如 jniLibs.srcDirs = ['libs']

    2. 编译测试。

    3. 通过Android Studio的Analyze APK功能[Build -> Analyze APK...], 或直接解开apk包,查看是apk的lib目录下是否已包含libsqlite.so文件


libsqlite_3150200.tar.gz


您认为此回答对您有帮助?

共有 46 位开发者认为此问题有帮助

我对此仍有疑问!继续追问