SDK 集成概述
大约 3 分钟
SDK 集成概述
介绍 flutter 集成相关内容。
前提条件
开始前,请注册有效的环信即时通讯 IM 开发者账号和取得 App key,见 环信即时通讯云管理后台。
集成环境
具体见 开发环境要求。
SDK 初始化
初始化是使用 SDK 的必要步骤,需在所有接口方法调用前完成。
如果进行多次初始化操作,只有第一次初始化以及相关的参数生效。
初始化示例代码:
await EMClient.getInstance.init(EMOptions(
appKey: "<#your app key#>",
));
// 通知 SDK UI 已准备好。该方法执行后才会收到 `EMChatRoomEventHandler`、`EMContactEventHandler` 和 `EMGroupEventHandler` 回调。
await EMClient.getInstance.startCallback();
注册用户
可以使用如下代码创建账号:
try {
await EMClient.getInstance.createAccount(userId, password);
} on EMError catch (e) {}
提示
- 以上注册模式为在客户端注册,主要用于测试,简单方便,但不推荐在正式环境中使用;
- 正式环境应调用 REST API 接口注册用户。
用户登录
目前登录服务器支持手动和自动登录。手动登录有两种方式:
- 用户 ID + 密码
- 用户 ID + token
手动登录时传入的用户 ID 必须为 String 类型,支持的字符集详见用户注册的 RESTful 接口。
调用登录接口后,收到 onConnected
回调表明 SDK 与环信服务器连接成功。
手动登录
用户 ID + 密码 登录是传统的登录方式。用户名和密码都是你的终端用户自行决定,密码需要符合密码规则要求。
try {
await EMClient.getInstance.login(userId, password);
} on EMError catch (e) {}
用户 ID + token 是更加安全的登录方式。token 可以通过调用 REST API 获取。 详见 环信用户 token 的获取。
提示
使用 token 登录时需要处理 token 过期的问题,比如在每次登录时更新 token 等机制。
try {
await EMClient.getInstance.login(userId, token, false);
} on EMError catch (e) {}
登录重试机制如下:
- 登录时,若服务器返回明确的失败原因,例如,token 不正确,SDK 不会重试登录。
- 若登录因超时失败,SDK 会重试登录。
自动登录
在初始化的时候,可以设置是否自动登录。如果设置为自动登录,则登录成功之后,后续启动初始化的时候会自动登录。
退出登录
try {
await EMClient.getInstance.logout(true);
} on EMError catch (e) {}
自动登录时,SDK 尝试连接服务器失败后,延时随机一段时间后自动重连。
连接状态相关
你可以通过注册连接监听来确认连接状态。
// 注册连接状态监听
EMClient.getInstance.addConnectionEventHandler(
"UNIQUE_HANDLER_ID",
EMConnectionEventHandler(
// sdk 连接成功;
onConnected: () => {},
// 由于网络问题导致的断开,sdk会尝试自动重连,连接成功后会回调 "onConnected";
onDisconnected: () => {},
// 用户 token 鉴权失败;
onUserAuthenticationFailed: () => {},
// 由于密码变更被踢下线;
onUserDidChangePassword: () => {},
// 用户被连接被服务器禁止;
onUserDidForbidByServer: () => {},
// 用户登录设备超出数量限制;
onUserDidLoginTooManyDevice: () => {},
// 用户从服务器删除;
onUserDidRemoveFromServer: () => {},
// 调用 `kickDevice` 方法将设备踢下线,被踢设备会收到该回调;
onUserKickedByOtherDevice: () => {},
// 登录新设备时因达到了登录设备数量限制而导致当前设备被踢下线,被踢设备收到该回调;
onUserDidLoginFromOtherDevice: (String deviceName) => {},
// Token 过期;
onTokenDidExpire: () => {},
// Token 即将过期,需要调用 renewToken;
onTokenWillExpire: () => {},
),
);
// 解注册连接状态监听
EMClient.getInstance.removeConnectionEventHandler(
"UNIQUE_HANDLER_ID",
);