IM 即时通讯 (441)
Android (208)
- 初始化&链接 (8)
- 事件&监听处理 (7)
- 用户信息 (13)
- 会话列表 (15)
- 聊天会话 (26)
- 消息处理 (35)
- 自定义消息 (6)
- 音视频 (2)
- 推送&通知 (34)
- 扩展功能 (4)
- 第三方地图 (3)
- 依赖&配置 (9)
- 升级说明 (3)
- 其他 (43)
iOS (168)
- SDK 导入 (10)
- 连接 (8)
- 事件处理 (2)
- 用户信息 (3)
- 会话列表 (14)
- 聊天会话 (44)
- 消息处理 (25)
- 自定义消息 (8)
- 推送&通知 (19)
- 扩展功能 (5)
- 国际化 (4)
- 音视频 (3)
- 其他 (23)
Web (36)
Server (29)
TargetSdkVersion 为24时,找不到libsqlite.so,导致连上无法连接服务器。
回答:
问题描述:
错误日志如下: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/armeabi-v7a/libsqlite.so,并注意你的gradle是否引用了这个目录,如 jniLibs.srcDirs = ['libs']
编译测试。
通过Android Studio的Analyze APK功能[Build -> Analyze APK...], 或直接解开apk包,查看是apk的lib目录下是否已包含libsqlite.so文件