问题描述:
错误日志如下: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文件了。
两种解决方案:
-
把targetSdkVersion改小于24。
-
apk中带上需要的so文件,这儿是libsqlite.so
-
下载附件中的so文件,放到对应的文件夹下,如libs/armv7-abi/libsqlite.so,并注意你的gradle是否引用了这个目录,如 jniLibs.srcDirs = ['libs']
-
编译测试。
-
通过Android Studio的Analyze APK功能[Build -> Analyze APK...], 或直接解开apk包,查看是apk的lib目录下是否已包含libsqlite.so文件
-
来源:http://support.rongcloud.cn/kb/NTQw