集成 SDK
大约 4 分钟
Andorid 集成文档
集成 SDK
本文介绍如何将环信即时通讯 IM SDK 集成到你的 Android 项目。
开发环境要求
- Android Studio 3.0 或以上版本;
- Android SDK API 等级 21 或以上;
- Android 5.0 或以上版本的设备。
集成 SDK
选择如下任意一种方式将环信即时通讯 IM SDK 集成到你的项目中。
提示
- 以下集成方式只需选择一种,同时使用多种集成方式可能会报错。
- 请点击查看发版说明获得最新版本号。
方法一:使用 mavenCentral 自动集成
提示
该方法仅适用于 v3.8.2 或以上版本。
- 在项目的
build.gradle
中添加mavenCentral()
仓库。
buildscript {
repositories {
...
mavenCentral()
}
...
}
allprojects {
repositories {
...
mavenCentral()
}
}
- 在
module
的build.gradle
中添加如下依赖:
...
dependencies {
...
// x.y.z 请填写具体版本号,必须为 3.8.2 或以上版本。
// 可通过 SDK 发版说明获得最新版本号。
implementation 'io.hyphenate:hyphenate-chat:x.x.x'
}
提示
如果使用 3.8.0 之前的版本,gradle 依赖需要按照下面格式添加:
implementation 'io.hyphenate:hyphenate-sdk:3.7.5' // 完整版本,包含音视频功能
implementation 'io.hyphenate:hyphenate-sdk-lite:3.7.5' // 精简版,只包含IM功能
方法二:手动复制 SDK 文件
打开 SDK 下载页面,获取最新版的环信即时通讯 IM Android SDK,然后解压。
将 SDK 包内 libs 路径下的如下文件,拷贝到你的项目路径下:
文件或文件夹 | 项目路径 |
---|---|
hyphenatechat_xxx.jar 文件 | /app/libs/ |
arm64-v8a 文件夹 | /app/src/main/jniLibs/ |
armeabi-v7a 文件夹 | /app/src/main/jniLibs/ |
x86 文件夹 | /app/src/main/jniLibs/ |
x86_64 文件夹 | /app/src/main/jniLibs/ |
如果对生成的 apk
大小比较敏感,我们建议使用 jar
方式,并且手工拷贝 so
,而不是使用 Aar
,因为 Aar
方式会把各个平台的 so
文件都包含在其中。采用 jar
方式,可以仅保留一个 ARCH
目录,建议仅保留 armeabi-v7a
,这样虽然在对应平台执行的速度会降低,但是能有效减小 apk
的大小。
方法三:动态加载 .so 库文件
为了减少应用安装包的大小,SDK 提供了 EMOptions#setNativeLibBasePath
方法支持动态加载 SDK 所需的 .so
文件。以 SDK 4.5.0 为例,.so
文件包括 libcipherdb.so
和 libhyphenate.so
两个文件。从 4.11.0 开始,.so
文件还包含 libaosl.so
文件。
该功能的实现步骤如下:
- 下载最新版本的 SDK 并解压缩。
- 集成
hyphenatechat_4.5.0.jar
到你的项目中。 - 将所有架构的
.so
文件上传到你的服务器,并确保应用程序可以通过网络下载目标架构的.so
文件。 - 应用运行时,会检查
.so
文件是否存在。如果未找到,应用会下载该.so
文件并将其保存到你自定义的应用程序的私有目录中。 - 调用
EMClient#init
初始化时,将.so
文件所在的 app 私有目录作为参数设置进EMOptions#setNativeLibBasePath
方法中。 - 调用
EMClient#init
初始化后,SDK 会自动从指定路径加载.so
文件。
提示
- 该方法仅适合手动集成 Android SDK,不适用于通过 Maven Central 集成。
- so 库的路径取决于
EMOptions#setNativeLibBasePath
方法的path
参数:
- 若设置了
path
参数,SDK 内部会使用System.load
从设置的路径下搜索和加载 so 库。该路径必须为有效的 app 的私有目录路径。 path
参数为空或者不调用该方法时,SDK 内部会使用system.loadLibrary
从系统默认路径中搜索并加载 so 库。
//假设用户已经通过动态下发的方式,将环信 SDK 中的 libcipherdb.so 和 libhyphenate.so 两个 so 库,放到 app 的 /data/data/packagename/files 目录下。
String filesPath = mContext.getFilesDir().getAbsolutePath();
EMOptions options = new EMOptions();
options.setNativeLibBasePath(filesPath);
EMClient.getInstance().init(mContext, options);
添加项目权限
根据场景需要,在 /app/src/main/AndroidManifest.xml
文件中添加如下行,获取相应的设备权限:
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="https://schemas.android.com/apk/res/android"
package="Your Package"
android:versionCode="100"
android:versionName="1.0.0">
<!-- IM SDK required start -->
<!-- 允许程序振动,用于本地通知设置振动 -->
<uses-permission android:name="android.permission.VIBRATE" />
<!-- 访问网络权限 -->
<uses-permission android:name="android.permission.INTERNET" />
<!-- 麦克风权限,用于语音消息时录制语音,不使用录制语音可以移除 -->
<uses-permission android:name="android.permission.RECORD_AUDIO" />
<!-- 相机权限,用于图片消息时拍摄图片,不使用拍照可以移除 -->
<uses-permission android:name="android.permission.CAMERA" />
<!-- 获取运营商信息,用于获取网络状态 -->
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/>
<!-- 获取读存储权限,用于附件等的获取 -->
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/>
<!-- 访问 GPS 定位,用于定位消息,如果不用定位相关可以移除 -->
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION"/>
<!-- 允许程序在手机屏幕关闭后后台进程仍然运行 -->
<uses-permission android:name="android.permission.WAKE_LOCK" />
<!-- 申请闹钟定时权限,SDK 心跳中使用,3.9.8及以后版本可以不添加 -->
<uses-permission android:name="android.permission.SCHEDULE_EXACT_ALARM" />
<!-- IM SDK required end -->
</manifest>
防止代码混淆
在 app/proguard-rules.pro
文件中添加如下行,防止混淆 SDK 的代码:
-keep class com.hyphenate.** {*;}
-dontwarn com.hyphenate.**