Skip to content

Latest commit

 

History

History
2220 lines (1557 loc) · 65.7 KB

README.zh-cn.md

File metadata and controls

2220 lines (1557 loc) · 65.7 KB

Open-IM-SDK-Android

1. 初始化与登录

1.1. initSDK

初始化OpenIM SDK,设置SDK网络连接地址以及本地数据存放目录等。

OpenIMClient.getInstance().initSDK(platform, ipApi, ipWs, dbPath, new InitSDKListener() {
        @Override
        public void onConnectFailed(long code, String error) {
        }

        @Override
        public void onConnectSuccess() {
        }

        @Override
        public void onConnecting() {
        }

        @Override
        public void onKickedOffline() {
        }

        @Override
        public void onSelfInfoUpdated(UserInfo info) {
        }

        @Override
        public void onUserTokenExpired() {
        }
});
  • 参数说明:
名称 类型 描述
platform int 平台类型:IMPlatform类
ipApi String SDK的API接口地址。如:http:xxx:10000
ipWs String SDK的web socket地址。如: ws:xxx:17778
dbPath String 数据存储路径。如:context.getCacheDir().getAbsolutePath()
listener OnInitSDKListener SDK初始化监听

注:在创建图片,语音,视频,文件等需要路径参数的消息体时,如果选择的是非全路径方法如:createSoundMessage(全路径方法为:createSoundMessageFromFullPath),需要将文件自行拷贝到dbPath目录下,如果此时文件路径为 apath+"/sound/a.mp3",则参数path的值为:/sound/a.mp3。如果选择的全路径方法,路径为你文件的实际路径不需要再拷贝。

  • OnInitSDKListener
事件回调 事件描述 推荐操作
onConnecting 正在连接到服务器 适合在 UI 上展示“正在连接”状态。
onConnectSuccess 连接服务器失败 -
onConnectFailed 已经成功连接到服务器 可以提示用户当前网络连接不可用
onKickedOffline 当前用户被踢下线 此时可以 UI 提示用户“您已经在其他端登录了当前账号,是否重新登录?”
onUserSigExpired 登录票据已经过期 请使用新签发的 UserSig 进行登录。
onSelfInfoUpdated 当前用户的资料发生了更新 可以在 UI 上更新自己的头像和昵称。

1.2. login

使用用户ID(uid)和token登录,uid来自于自身业务服务器,token需要业务服务器根据secret向OpenIM服务端交换获取。

OpenIMClient.getInstance().login(new OnBase<String>() {
    @Override
    public void onError(long code, String error) {
    }

    @Override
    public void onSuccess(String data) {
    }
}, uid, token);
  • 参数说明
名称 类型 描述
uid String 用户ID
token String 用户token

1.3. logout

登出OpenIM,通常在切换账号的时候调用,清除登录态以及内存中的所有数据。

OpenIMClient.getInstance().logout(new OnBase<String>() {
    @Override
    public void onError(long code, String error) {
    }

    @Override
    public void onSuccess(String data) {
    }
});

1.4. getLoginStatus

获取当前用户登录状态。

int value = OpenIMClient.getInstance().getLoginStatus();
  • 返回值说明:
if (value == 101) {
    // 登录成功
}

1.5. getLoginUid

获取当前登录用户ID。

String uid = OpenIMClient.getInstance().getLoginUid();

1.6. getLoginUserInfo

获取当前登录用户的信息

List<String> ids = new ArrayList<>();
ids.add(uid); // uid =  getLoginUid()
OpenIMClient.getInstance().getUsersInfo(new OnBase<List<UserInfo>>() {
    @Override
    public void onError(long code, String error) {
    }

    @Override
    public void onSuccess(List<UserInfo> data) {
    }
}, ids);

1.7. setSelfInfo

修改当前登录用户信息

OpenIMClient.getInstance().setSelfInfo(new OnBase<String>() {
    @Override
    public void onError(long code, String error) {
    }

    @Override
    public void onSuccess(String data) {
    }
}, name, icon, gender, mobile, birth, email);

参数说明:

名称 类型 描述
name String 用户名
icon String 头像
gender int 性别:1女,2男
mobile String 手机号
birth String 出生日期
email String 邮箱

1.8. unInitSDK

取消初始化,一般用于在初始化后需要重新初始化

OpenIMClient.getInstance().unInitSDK();

2. 用户资料

2.1. getUsersInfo

根据用户ID批量获取用户信息

List<String> ids = new ArrayList<>();
ids.add(uid1);
ids.add(uid2);
OpenIMClient.getInstance().getUsersInfo(new OnBase<List<UserInfo>>() {
    @Override
    public void onError(long code, String error) {
    }
    
    @Override
    public void onSuccess(List<UserInfo> data) {
    }
}, ids);
  • 参数说明:
名称 类型 描述
uidList List< String > 用户ID集合
  • 返回值说明:
类型 描述
List< UserInfo> 用户信息列表

3. 消息

3.1. createTextMessage

创建一条文字消息。

OpenIMClient.getInstance().messageManager.createTextMessage(text);
  • 参数说明:
名称 类型 描述
text String 消息内容

返回值说明:

类型 描述
Message 消息对象

3.2. createTextAtMessage

创建一条@消息

OpenIMClient.getInstance().messageManager.createTextAtMessage(text,atUidList);
  • 参数说明:
名称 类型 描述
text String 消息内容
atUidList List< String> 选择的用户id集合

3.3. createImageMessage

创建图片消息

OpenIMClient.getInstance().messageManager.createImageMessage(imagePath);
  • 参数说明:
名称 类型 描述
imagePath String 图片的相对路径

注:initSDK时传入了数据缓存路径,如路径:A,这时需要你将图片复制到A路径下后,如 A/pic/a.png路径,imagePath的值:“/pic/a.png”。

3.4. createImageMessageFromFullPath

创建图片消息(绝对路径)

OpenIMClient.getInstance().messageManager.createImageMessageFromFullPath(imagePath);
  • 参数说明:
名称 类型 描述
imagePath String 图片在设备上的的绝对路径

此方法不需要拷贝,推荐使用。

3.5. createSoundMessage

创建语音消息

OpenIMClient.getInstance().messageManager.createSoundMessage(soundPath, duration);
  • 参数说明:
名称 类型 描述
soundPath String 相对路径
duration int 语音时长,单位秒

注:initSDK时传入了数据缓存路径,如路径:A,这时需要你将语音文件复制到A路径下后,如 A/sound/a.m4a路径,soundPath的值:“/sound/a.m4a”。

3.6. createSoundMessageFromFullPath

创建语音消息(绝对路径)

OpenIMClient.getInstance().messageManager.createSoundMessageFromFullPath(soundPath, duration);
  • 参数说明:
名称 类型 描述
soundPath String 在设备上的的绝对路径
duration int 语音时长,单位秒

此方法不需要拷贝,推荐使用。

3.7. createVideoMessage

创建视频消息

OpenIMClient.getInstance().messageManager.createVideoMessage(videoPath, videoType, duration, snapshotPath);
  • 参数说明:
名称 类型 描述
videoPath String 相对路径
videoType String 文件的mineType
duration int 视频时长,单位秒
snapshotPath String 视频的缩略图

注:initSDK时传入了数据缓存路径,如路径:A,这时需要你将视频文件复制到A路径下后,如 A/video/a.mp4路径,videoPath的值:“/video/a.mp4”

3.8. createVideoMessageFromFullPath

创建视频消息(绝对路径)

OpenIMClient.getInstance().messageManager.createVideoMessageFromFullPath(videoPath, videoType, duration, snapshotPath);
  • 参数说明:
名称 类型 描述
videoPath String 在设备上的的绝对路径
videoType String 文件的mineType
duration int 视频时长,单位秒
snapshotPath String 视频的缩略图

此方法不需要拷贝,推荐使用。

3.9. createFileMessage

创建文件消息

OpenIMClient.getInstance().messageManager.createFileMessage(filePath, fileName);
  • 参数说明:
名称 类型 描述
filePath String 相对路径
fileName String 文件名

注:initSDK时传入了数据缓存路径,如路径:A,这时需要你将视频文件复制到A路径下后,如 A/file/a.txt路径,filePath的值:“/file/a.txt”

3.10. createFileMessageFromFullPath

创建文件消息(绝对路径)

OpenIMClient.getInstance().messageManager.createFileMessageFromFullPath(filePath, fileName);
  • 参数说明:
名称 类型 描述
filePath String 在设备上的的绝对路径
fileName String 文件名

此方法不需要拷贝,推荐使用。

3.11. createLocationMessage

创建位置消息

OpenIMClient.getInstance().messageManager.createLocationMessage(latitude, longitude, description);
  • 参数说明:
名称 类型 描述
latitude double 纬度
longitude double 经度
description String 描述信息,可以根据自己的需求传任何数据

description:在位置消息展示时,有位置名,位置描述,定位图片信息。
推荐 description:

{"title":"天府新谷","detail":"四川省高新区石羊街道府城大道西段399号","url":"https://apis.map.qq.com/ws/staticmap/v2/?center=%s&zoom=18&size=600*300&maptype=roadmap&markers=size:large|color:0xFFCCFF|label:k|%s&key=TMNBZ-3CGC6-C6SSL-EJA3B-E2P5Q-V7F6Q"}

3.12. createQuoteMessage

创建引用消息

OpenIMClient.getInstance().messageManager.createQuoteMessage(text, message);
  • 参数说明:
名称 类型 描述
text String 消息内容
quoteMsg Message对象 被引用的消息对象Message

3.13. createCardMessage

创建名片消息

OpenIMClient.getInstance().messageManager.createCardMessage(content);
  • 参数说明:
名称 类型 描述
content String json字符串,按需求自定义内容。

3.14. createMergerMessage

创建合并消息

OpenIMClient.getInstance().messageManager.createMergerMessage(messageList, title, summaryList);
  • 参数说明:
名称 类型 描述
title String 标题
summaryList List< String> 摘要
messageList List< Message> 被选中的消息集合

3.15. createForwardMessage

创建转发消息

OpenIMClient.getInstance().messageManager.createForwardMessage(message);
  • 参数说明:
名称 类型 描述
message Message 被选择转发的Message对象

3.16. createCustomMessage

创建自定义消息

OpenIMClient.getInstance().messageManager.createCustomMessage(data, extension, description);
  • 参数说明:
名称 类型 描述
data String 自定义json数据
extension String 自定义json数据
description String 自定义json数据

3.17. sendMessage

发送消息

OpenIMClient.getInstance().messageManager.sendMessage(new OnMsgSendCallback() {               
    @Override
    public void onError(long code, String error) {
    }

    @Override
    public void onProgress(long progress) {
        // 消息发送进度监听,主要用途:图片,视频,文件等上传进度监听。
    }

    @Override
    public void onSuccess(String s) {
    }
}, message, recvUid, recvGid, onlineUserOnly);
  • 参数说明:
名称 类型 描述
message Message 创建的消息结构体
userID String 单聊对象的用户id
groupID String 群聊id
onlineUserOnly boolean 是否仅在线用户接收

注:如果一对一聊天 userID 不能为空。如果群聊天 groupID 不能为空。

3.18. typingStatusUpdate

提示用户正在输入

OpenIMClient.getInstance().messageManager.typingStatusUpdate(userID, typing);
  • 参数说明:
名称 类型 描述
userID String 单聊对象的用户id
typing boolean typing:true正在输入,false停止输入

注:单聊使用此功能,在收到的新消息回调里如果消息类型为typing消息且typing == 'yes'提示正在输入。typing=='no'取消提示

3.19. revokeMessage

撤回消息

OpenIMClient.getInstance().messageManager.revokeMessage(new OnBase<String>() {
    @Override
    public void onError(long code, String error) {
    }
    
    @Override
    public void onSuccess(String data) {
    }
}, message);
  • 参数说明:
名称 类型 描述
message Message 被撤回的消息体

注:调用此方法会触发消息撤回回调,可以在回调里移除界面上的消息显示。也会触发新增消息回调,新增的消息类型为撤回消息类型,可以在界面显示一条xx撤回了一条消息

3.20. markC2CMessageAsRead

标记接收的消息为已读

OpenIMClient.getInstance().messageManager.markC2CMessageAsRead(new OnBase<String>() {
    @Override
    public void onError(long code, String error) {
    }
    
    @Override
    public void onSuccess(String data) {
    }
}, userID, messageIDList);
  • 参数说明:
名称 类型 描述
userID String 单聊对象的用户id
messageIDList List< String> 被标记为已读消息的消息id

注:单聊使用此功能,调用此方法会触发对方的c2c消息已读回调,可以在回调里修改界面上的消息已读状态

3.21. getHistoryMessageList

获取聊天记录

OpenIMClient.getInstance().messageManager.getHistoryMessageList(new OnBase<List<Message>>() {
    @Override
    public void onError(long code, String error) {
    }
    
    @Override
    public void onSuccess(List<Message> data) {
    }
},  userID,  groupID,  startMsg,  count);
  • 参数说明:
名称 类型 描述
userID String 单聊对象的用户id
groupID String 群聊id
count int 拉取的条数
startMsg Message 从哪一个消息开始

注:startMsg:如第一次拉取20条记录 startMsg=null && count=20 得到List< Message> list;下一次拉取消息记录参数:startMsg=list.first && count =20;以此内推,startMsg始终为list的第一条。

3.22. addAdvancedMsgListener

添加消息监听

OpenIMClient.getInstance().messageManager.addAdvancedMsgListener(new OnAdvanceMsgListener() {
    @Override
    public void onRecvNewMessage(Message msg) {
        // 如果是当前窗口的消息
        if (isCurrentChat(message)) {
            // 正在输入消息
            if (message.contentType == MessageType.typing) {
                //
            } else {
                // 新增消息
                if (!messageList.contains(message)) {
                    messageList.add(message);
                }
            }
        }
    }
    
    @Override
    public void onRecvC2CReadReceipt(List<HaveReadInfo> list) {
        // 消息已读回执
        messageList.forEach((e) {
            // 获取当前聊天窗口的已读回执
            var info = list.firstWhere((element) => element.uid == uid);
            // 标记消息列表里对应的消息为已读状态
            if (info.msgIDList?.contains(e.clientMsgID) == true) {
                e.isRead = true;
            }
        });
    }
    
    @Override
    public void onRecvMessageRevoked(String msgId) {
        // 消息被撤回回调
        var revokedMsg = Message(clientMsgID: msgId);
        messageList.remove(revokedMsg);
    }
});
事件回调 事件描述 推荐操作
recvMessageRevoked 消息成功撤回 从界面移除消息
recvC2CReadReceipt 消息被阅读回执 将消息标记为已读
recvNewMessage 收到新消息 界面添加新消息

3.23. removeAdvancedMsgListener

移除消息监听

OpenIMClient.getInstance().messageManager.removeAdvancedMsgListener(listener);
  • 参数说明:
名称 类型 描述
listener OnAdvancedMsgListener对象 listener为3.22中创建的实例

3.24. deleteMessageFromLocalStorage

删除本地消息。

OpenIMClient.getInstance().messageManager.deleteMessageFromLocalStorage(new OnBase<String>() {
    @Override
    public void onError(long code, String error) {
    }
    
    @Override
    public void onSuccess(String data) {
    }
}, message);
  • 参数说明:
名称 类型 描述
message Message 被删除的消息对象

3.25. insertSingleMessageToLocalStorage

插入一条消息到本地。

OpenIMClient.getInstance().messageManager.insertSingleMessageToLocalStorage(new OnBase<String>() {
    @Override
    public void onError(long code, String error) {
    }
    
    @Override
    public void onSuccess(String data) {
    }
}, message,  receiver,  sender);
  • 参数说明:
名称 类型 描述
recevier String 接收者ID
sender String 发送者ID
message Message 消息结构体

3.26. findMessages

根据消息ID查找本地消息。

OpenIMClient.getInstance().messageManager.findMessages(new OnBase<List<Message>>() {
    @Override
    public void onError(long code, String error) {
    }
    
    @Override
    public void onSuccess(List<Message> data) {
    }
}, messageIDList);
  • 参数说明:
名称 类型 描述
messageIDList List< String> 消息id(clientMsgID)集合

4. 会话

4.1. getAllConversationList

拉取当前所有的会话记录

OpenIMClient.getInstance().conversationManager.getAllConversationList(new OnBase<List<ConversationInfo>>() {
    @Override
    public void onError(long code, String error) {
    }
    
    @Override
    public void onSuccess(List<ConversationInfo> data) {
    }
});

4.2. getOneConversation

根据用户ID或群聊ID和session类型获取单个会话。

OpenIMClient.getInstance().conversationManager.getOneConversation(new OnBase<ConversationInfo>() {
    @Override
    public void onError(long code, String error) {
    }
    
    @Override
    public void onSuccess(ConversationInfo data) {
    }
}, sourceId, sessionType);
  • 参数说明:
名称 类型 描述
sourceID String 如果是单聊其值为单聊对象的userId;如果是群聊其值为群的groupId
sessionType String 如果是单聊sessionType=1;群聊sessionType=2

4.3. getMultipleConversation

根据会话ID获取多个会话。

OpenIMClient.getInstance().conversationManager.getMultipleConversation(new OnBase<List<ConversationInfo>>() {
    @Override
    public void onError(long code, String error) {
    }
    
    @Override
    public void onSuccess(List<ConversationInfo> data) {
    }
}, conversationIDList);
  • 参数说明:
名称 类型 描述
conversationIDList List< String> 会话的id集合

4.4. deleteConversation

删除会话,执行此操作会触发会话记录发生改变回调。

OpenIMClient.getInstance().conversationManager.deleteConversation(new OnBase<String>() {
    @Override
    public void onError(long code, String error) {
    }
    
    @Override
    public void onSuccess(String data) {
    }
}, conversationID);
  • 参数说明:
名称 类型 描述
conversationID String 被删除的会话id

4.5. setConversationDraft

设置草稿,执行此操作会触发会话记录发生改变回调。

OpenIMClient.getInstance().conversationManager.setConversationDraft(new OnBase<String>() {
    @Override
    public void onError(long code, String error) {
    }
    
    @Override
    public void onSuccess(String data) {
    }
}, conversationID,  draftText);
  • 参数说明:
名称 类型 描述
draftText String 未完成发送的消息内容
conversationID String 会话id

4.6. pinConversation

置顶会话,执行此操作会触发会话记录发生改变回调。

OpenIMClient.getInstance().conversationManager.pinConversation(new OnBase<String>() {
    @Override
    public void onError(long code, String error) {
    }
    
    @Override
    public void onSuccess(String data) {
    }
}, conversationID,  isPinned);
  • 参数说明:
名称 类型 描述
isPinned boolean true:置顶,false:取消置顶
conversationID String 会话id

注:ConversationInfo对象里的isPinned字段,isPinned==1代表置顶

4.7. markSingleMessageHasRead

标记单聊会话消息为已读。

OpenIMClient.getInstance().conversationManager.markSingleMessageHasRead(new OnBase<String>() {
    @Override
    public void onError(long code, String error) {
    }
    
    @Override
    public void onSuccess(String data) {
    }
}, userID);
  • 参数说明:
名称 类型 描述
userID String 单聊用户id

4.8. markGroupMessageHasRead

标记群聊会话消息已读。

OpenIMClient.getInstance().conversationManager.markGroupMessageHasRead(new OnBase<String>() {
    @Override
    public void onError(long code, String error) {
    }
    
    @Override
    public void onSuccess(String data) {
    }
}, groupID);
  • 参数说明:
名称 类型 描述
groupID String 群组id

4.9. getTotalUnreadMsgCount

获取消息总未读。

OpenIMClient.getInstance().conversationManager.getTotalUnreadMsgCount(new OnBase<String>() {
    @Override
    public void onError(long code, String error) {
    }
    
    @Override
    public void onSuccess(String data) {
    }
});

4.10. setConversationListener

设置会话监听器,会话记录发生改变时回调。

OpenIMClient.getInstance().conversationManager.setOnConversationListener(new OnConversationListener() {
    @Override
    public void onConversationChanged(List<ConversationInfo> list) {
        // 会话记录改变
    }
    
    @Override
    public void onNewConversation(List<ConversationInfo> list) {
        // 新增会话            
    }            
    
    @Override
    public void onSyncServerFailed() {
    }
    
    @Override
    public void onSyncServerFinish() {
    }
    
    @Override
    public void onSyncServerStart() {
    }
    
    @Override
    public void onTotalUnreadMessageCountChanged(int i) {
        // 未读消息总数改变
    }        
});
事件回调 事件描述 推荐操作
conversationChanged 会话记录发生改变 刷新会话列表
newConversation 有新的会话被添加 刷新会话列表
totalUnreadMsgCountChanged 未读消息总数发生改变 刷新消息未读数

5.好友关系

5.1. getFriendList

获取好友列表。

OpenIMClient.getInstance().friendshipManager.getFriendList(new OnBase<List<UserInfo>>() {
    @Override
    public void onError(long code, String error) {
    }
    
    @Override
    public void onSuccess(List<UserInfo> data) {
    }
});

5.2. getFriendsInfo

获取好友信息。

OpenIMClient.getInstance().friendshipManager.getFriendsInfo(new OnBase<List<UserInfo>>() {
    @Override
    public void onError(long code, String error) {
    }
    
    @Override
    public void onSuccess(List<UserInfo> data) {
    }
}, uidList);
  • 参数说明:
名称 类型 描述
uidList List< String> 用户的ID集合

5.3. setFriendInfo

设置好友备注信息。

OpenIMClient.getInstance().friendshipManager.setFriendInfo(new OnBase<String>() {            
    @Override
    public void onError(long code, String error) {
    }
    
    @Override
    public void onSuccess(String data) {
    }
}, uid,  comment);
  • 参数说明:
名称 类型 描述
uid String 用户的ID
comment String 备注

5.4. checkFriend

检查与用户间是否有好友关系。

OpenIMClient.getInstance().friendshipManager.checkFriend(new OnBase<List<UserInfo>>() {
    @Override
    public void onError(long code, String error) {
    }
    
    @Override
    public void onSuccess(List<UserInfo> data) {
    }
}, uidList);
  • 参数说明:
名称 类型 描述
uidList List< String> 用户的ID集合

根据类UserInfo的flag字段判断。flag == 1:是好友关系,其他非好友关系。

5.5. deleteFromFriendList

从好友列表中删除用户。

OpenIMClient.getInstance().friendshipManager.deleteFromFriendList(new OnBase<String>() {
    @Override
    public void onError(long code, String error) {
    }
    
    @Override
    public void onSuccess(String data) {
    }
}, uid);
  • 参数说明:
名称 类型 描述
uid String 用户的ID

5.6. addFriend

发起添加好友申请。

OpenIMClient.getInstance().friendshipManager.addFriend(new OnBase<String>() {            
    @Override
    public void onError(long code, String error) {
    }
    
    @Override
    public void onSuccess(String data) {
    }
}, uid, reason);
  • 参数说明:
名称 类型 描述
uid String 用户的ID
reason String 添加说明

5.7. getFriendApplicationList

获取好友请求列表。

OpenIMClient.getInstance().friendshipManager.getFriendApplicationList(new OnBase<List<UserInfo>>() {
    @Override
    public void onError(long code, String error) {
    }
    
    @Override
    public void onSuccess(List<UserInfo> data) {
    }
});

UserInfoflag 字段:flag == 0:等待处理;flag == 1:已添加;flag == -1:已拒绝。

注:新朋友的红点数通过计算列表里flag == 0的item的数量。

5.8. acceptFriendApplication

接受好友请求。

OpenIMClient.getInstance().friendshipManager.acceptFriendApplication(new OnBase<String>() {
    @Override
    public void onError(long code, String error) {
    }
    
    @Override
    public void onSuccess(String data) {
    }
}, uid);

uid:为好友申请列表返回的数据里 UserInfo 类的 uid 字段。

5.9. refuseFriendApplication

拒绝好友请求。

OpenIMClient.getInstance().friendshipManager.refuseFriendApplication(new OnBase<String>() {
    @Override
    public void onError(long code, String error) {
    }
    
    @Override
    public void onSuccess(String data) {
    }
}, uid);

5.10. addToBlackList

将用户添加到黑名单。

OpenIMClient.getInstance().friendshipManager.addToBlackList(callback, uid);

返回Future,执行then方法为操作成功,执行cathError方法为操作失败。

5.11. deleteFromBlackList

从黑名单移除用户。

OpenIMClient.getInstance().friendshipManager.addToBlackList(new OnBase<String>() {            
    @Override
    public void onError(long code, String error) {
    }
    
    @Override
    public void onSuccess(String data) {
    }
}, uid);

5.12. getBlackList

获取黑名单列表。

OpenIMClient.getInstance().friendshipManager.getBlackList(new OnBase<List<UserInfo>>() {
    @Override
    public void onError(long code, String error) {
    }
    
    @Override
    public void onSuccess(List<UserInfo> data) {
    }
});

注:如果好友被拉进黑名单,调用getFriendList 或 getFriendListMap方法得到好友包含了黑名单的人,需要通过UserInfo类的isInBlackList字段筛选,如果isInBlackList == 1说明被拉入黑名单。

5.13. setFriendListener

设置好友监听器。

OpenIMClient.getInstance().friendshipManager.setOnFriendshipListener(new OnFriendshipListener() {
    @Override
    public void onBlackListAdd(UserInfo u) {
    }
    
    @Override
    public void onBlackListDeleted(UserInfo u) {
    }
    
    @Override
    public void onFriendApplicationListAccept(UserInfo u) {
    }
    
    @Override
    public void onFriendApplicationListAdded(UserInfo u) {
    }
    
    @Override
    public void onFriendApplicationListDeleted(UserInfo u) {
    }
    
    @Override
    public void onFriendApplicationListReject(UserInfo u) {
    }
    
    @Override
    public void onFriendInfoChanged(UserInfo u) {
    }
    
    @Override
    public void onFriendListAdded(UserInfo u) {
    }
    
    @Override
    public void onFriendListDeleted(UserInfo u) {
    }
});
事件回调 事件描述 推荐操作
blackListAdd 好友被加入黑名 刷新好友列表或黑名单列表
blackListDeleted 好友从黑名单移除 刷新好友列表或黑名单列表
friendApplicationListAccept 发起的好友请求被接受 刷新好友请求列表
friendApplicationListAdded 有新的好友申请 刷新好友请求列表
friendApplicationListDeleted 删除好友请求 刷新好友请求列表
friendApplicationListReject 请求被拒绝 刷新好友请求列表
friendInfoChanged 好友资料发生变化 刷新好友列表,好友信息或黑名单列表
friendListAdded 已成为好友 刷新好友列表
friendListDeleted 好友被删除 刷新好友列表

6. 群关系

6.1. createGroup

创建一个群聊,并指定群信息以及群成员。

OpenIMClient.getInstance().groupManager.createGroup(new OnBase<String>() {            
    @Override
    public void onError(long code, String error) {
    }
    
    @Override
    public void onSuccess(String data) {
    }
}, groupName, notification, introduction, faceUrl, list);
  • 参数说明:
名称 类型 描述
groupName String 群名
notification String 群公告
introduction String 群介绍
faceUrl String 群icon
list List< GroupMemberRole> 在发起群聊时选择的群成员列表。
GroupMemberRole类字段说明:setRole:0:普通成员 2:管理员;uid:成员的uid。

6.2. getGroupsInfo

批量获取群组信息。

OpenIMClient.getInstance().groupManager.getGroupsInfo(new OnBase<List<GroupInfo>>() {
    @Override
    public void onError(long code, String error) {
    }
    
    @Override
    public void onSuccess(List<GroupInfo> data) {
    }
}, gidList);
  • 参数说明:
名称 类型 描述
gidList List< String> 群组id集合

6.3. setGroupInfo

设置、更新群聊信息。

OpenIMClient.getInstance().groupManager.setGroupInfo(new OnBase<String>() {            
    @Override
    public void onError(long code, String error) {
    }
    
    @Override
    public void onSuccess(String data) {
    }
}, groupName, notification, introduction, faceUrl);

6.4. getJoinedGroupList

获取已加入的群列表。

OpenIMClient.getInstance().groupManager.getJoinedGroupList(new OnBase<List<GroupInfo>>() {
    @Override
    public void onError(long code, String error) {
    }
    
    @Override
    public void onSuccess(List<GroupInfo> data) {
    }
});

如果类 GroupInfoownerId 字段的值跟当前用户的 uid 一致,则当前用户就是群的发起者。否则是参与者。

6.5. getGroupMemberList

获取群成员列表。

GroupMembersList 类的nextSeq字段:下一页的开始 indexdata 字段:群成员。

OpenIMClient.getInstance().groupManager.getGroupMemberList(new OnBase<GroupMembersList>() {
    @Override
    public void onError(long code, String error) {
    }
    
    @Override
    public void onSuccess(GroupMembersList data) {
    }
}, groupId, filter, next);
  • 参数说明:
名称 类型 描述
groupId String 群组id
filter int 过滤成员,0不过滤,1群的创建者,2管理员;默认值0
next int 分页,从哪一条开始获取,默认值0。参照GroupMembersList的nextSeq字段的值。

6.6. getGroupMembersInfo

批量获取群成员信息。

OpenIMClient.getInstance().groupManager.getGroupMembersInfo(new OnBase<List<GroupMembersInfo>>() {
    @Override
    public void onError(long code, String error) {
    }
    
    @Override
    public void onSuccess(List<GroupMembersInfo> data) {
    }
}, groupId, uidList);
  • 参数说明:
名称 类型 描述
groupId String 群组id
uidList List< String> 群成员ID集合

6.7. joinGroup

申请加入群聊。

OpenIMClient.getInstance().groupManager.joinGroup(new OnBase<String>() {            
    @Override
    public void onError(long code, String error) {
    }
    
    @Override
    public void onSuccess(String data) {
    }
}, gid, reason);
  • 参数说明:
名称 类型 描述
gid String 群组id
reason String 请求验证信息

6.8. getGroupApplicationList

获取加入群聊申请列表。

OpenIMClient.getInstance().groupManager.getGroupApplicationList(new OnBase<GroupApplicationList>() {
    @Override
    public void onError(long code, String error) {
    }
    
    @Override
    public void onSuccess(GroupApplicationList data) {
    }
});
  • GroupApplicationList字段说明:
名称 类型 描述
count int 未处理数
user List< GroupApplicationInfo> 申请列表

6.9. acceptGroupApplication

同意入群请求。

OpenIMClient.getInstance().groupManager.acceptGroupApplication(new OnBase<String>() {
    @Override
    public void onError(long code, String error) {
    }
    
    @Override
    public void onSuccess(String data) {
    }
}, info, reason);
  • 参数说明:
名称 类型 描述
info GroupApplicationInfo 取6.8里申请列表的item
reason String 同意原因

6.10. refuseGroupApplication

拒绝入群请求。

OpenIMClient.getInstance().groupManager.refuseGroupApplication(new OnBase<String>() {
    @Override
    public void onError(long code, String error) {
    }
    
    @Override
    public void onSuccess(String data) {
    }
}, info, reason);
  • 参数说明:
名称 类型 描述
info GroupApplicationInfo 取6.8里申请列表的item
reason String 拒绝入群原因

6.11. inviteUserToGroup

邀请用户加入群组(可批量)。

OpenIMClient.getInstance().groupManager.inviteUserToGroup(new OnBase<List<GroupInviteResult>>() {
    @Override
    public void onError(long code, String error) {
    }
    
    @Override
    public void onSuccess(List<GroupInviteResult> data) {
    }
}, groupId, uidList, reason);
  • 参数说明:
名称 类型 描述
groupId String 群聊ID
uidList List< String> 邀请用户的id集合
reason String 请求验证信息

6.12. kickGroupMember

踢出群聊(可批量)。

OpenIMClient.getInstance().groupManager.kickGroupMember(new OnBase<List<GroupInviteResult>>() {
    @Override
    public void onError(long code, String error) {
    }
    
    @Override
    public void onSuccess(List<GroupInviteResult> data) {
    }
}, groupId, uidList, reason);
  • 参数说明:
名称 类型 描述
groupId String 群聊ID
uidList List< String> 踢出用户ID集合
reason String 踢出原因

6.13. quitGroup

退出群聊。

OpenIMClient.getInstance().groupManager.quitGroup(new OnBase<String>() {            
    @Override
    public void onError(long code, String error) {
    }
    
    @Override
    public void onSuccess(String data) {
    }
}, gid);

6.14. transferGroupOwner

转让群主。

OpenIMClient.getInstance().groupManager.transferGroupOwner(new OnBase<String>() {            
    @Override
    public void onError(long code, String error) {
    }
    
    @Override
    public void onSuccess(String data) {
    }
}, gid, uid);
  • 参数说明:
名称 类型 描述
gid String 群id
uid String 新的拥有者uid

注:此方法只有群的发起者(拥有者)才有权限访问,管理员和普通成员无权限访问。如果是发起者群资料展示可显示群权限转移按钮。

6.15. setGroupListener

设置群组监听器。

OpenIMClient.getInstance().groupManager.setOnGroupListener(new OnGroupListener() {            
    @Override
    public void onMemberEnter(String groupId, List<GroupMembersInfo> list) {
    }
    
    @Override
    public void onMemberLeave(String groupId, GroupMembersInfo info) {
    }
    
    @Override
    public void onMemberInvited(String groupId, GroupMembersInfo opUser, List<GroupMembersInfo> list) {
    }
    
    @Override
    public void onMemberKicked(String groupId, GroupMembersInfo opUser, List<GroupMembersInfo> list) {
    }
    
    @Override
    public void onGroupCreated(String groupId) {
    }
    
    @Override
    public void onGroupInfoChanged(String groupId, GroupInfo info) {
    }
    
    @Override
    public void onReceiveJoinApplication(String groupId, GroupMembersInfo info, String opReason) {
    }
    
    @Override
    public void onApplicationProcessed(String groupId, GroupMembersInfo opUser, int agreeOrReject, String opReason) {
    }
});
事件回调 事件描述 推荐操作
applicationProcessed 群申请被处理
groupCreated 群创建完成
groupInfoChanged 群资料发生变化 刷新群资料
memberEnter 进群 刷新群成员列表
memberInvited 接受邀请 刷新群成员列表
memberKicked 成员被踢出 刷新群成员列表
memberLeave 群成员退群 刷新群成员列表
receiveJoinApplication 收到入群申请

7. 数据对象结构

7.1. 用户信息对象

class UserInfo {
    String uid;
    String name;
    String icon;
    int gender;
    String mobile;
    String birth;
    String email;
    String ex;
    String comment;
    int isInBlackList;
    String reqMessage;
    String applyTime;
    int flag;
}
Field Description
uid 用户id
name 用户名
icon 用户头像
gender 性别:1男,2女
mobile 手机号
birth 生日
email 邮箱
ex 扩展字段
comment 备注
isInBlackList 黑名单:1已拉入黑名单
reqMessage 验证消息
applyTime 申请时间
flag 好友申请列表:0等待处理;1已同意;2已拒绝
好友关系:1已经是好友

7.2. 消息对象

class Message {
    String clientMsgID;
    String serverMsgID;
    int createTime;
    int sendTime;
    String sendID;
    String recvID;
    int msgFrom;
    int contentType; // [MessageType]
    int platformID;
    List<String> forceList;
    String senderNickName;
    String senderFaceUrl;
    String groupID;
    String content;
    int seq;
    boolean isRead;
    int status; // [MessageStatus]
    String remark;
    Object ext;
    int sessionType; // [ConversationType]
    PictureElem pictureElem;
    SoundElem soundElem;
    VideoElem videoElem;
    FileElem fileElem;
    AtElem atElem;
    LocationElem locationElem;
    CustomElem customElem;
    QuoteElem quoteElem;
    MergeElem mergeElem;
}

class PictureElem {
    String sourcePath;
    PictureInfo sourcePicture;
    PictureInfo bigPicture;
    PictureInfo snapshotPicture;
}

class PictureInfo {
    String uuID;
    String type;
    int size;
    int width;
    int height;
    String url;
}

class SoundElem {
    String uuID;
    String soundPath;
    String sourceUrl;
    int dataSize;
    int duration;
}

class VideoElem {
    String videoPath;
    String videoUUID;
    String videoUrl;
    String videoType;
    int videoSize;
    int duration;
    String snapshotPath;
    String snapshotUUID;
    int snapshotSize;
    String snapshotUrl;
    int snapshotWidth;
    int snapshotHeight;
}

class FileElem {
    String filePath;
    String uuID;
    String sourceUrl;
    String fileName;
    int fileSize;
}

class AtElem {
    String text;
    List<String> atUserList;
    boolean isAtSelf;
}

class LocationElem {
    String description;
    double longitude;
    double latitude;
}

class CustomElem {
    String data;
    String extension;
    String description;
}

class QuoteElem {
    String text;
    Message quoteMessage;
}

class MergeElem {
    String title;
    List<String> abstractList;
    List<Message> multiMessage;
}

7.2.1. Message

Field Description
clientMsgID 消息唯一ID
serverMsgID 消息服务器ID,暂时不使用
createTime 消息创建时间,单位纳秒
sendTime 消息发送时间,单位纳秒
sendID 发送者ID
recvID 接收者ID
msgFrom 标识消息是用户级别还是系统级别 100:用户 200:系统
contentType 消息类型:
101:文本消息
102:图片消息
103:语音消息
104:视频消息
105:文件消息
106:@消息
107:合并消息
108:转发消息
109:位置消息
110:自定义消息
111:撤回消息回执
112:C2C已读回执
113:正在输入状态
platformID 平台类型 1:ios 2:android 3:windows 4:osx 5:web 6:mini 7:linux
forceList 强制推送列表(被@的用户)
senderNickName 发送者昵称
senderFaceUrl 发送者头像
groupID 群聊ID
content 消息内容
seq 消息唯一序列号
isRead 是否已读
status 消息状态 1:发送中 2:发送成功 3:发送失败 4:已删除 5:已撤回
remark 消息备注
sessionType 会话类型 1:单聊 2:群聊
pictureElem 图片信息
soundElem 语音信息
videoElem 视频信息
fileElem 文件信息
atElem @信息
locationElem 位置信息
customElem 自定义信息
quoteElem 引用消息
mergeElem 合并信息

7.2.2. PictureElem

Field Description
sourcePath 本地资源地址
sourcePicture 本地图片详情
bigPicture 大图详情
snapshotPicture 缩略图详情

7.2.3. PictureInfo

Field Description
uuid 唯一ID
type 图片类型
size 图片大小
width 图片宽度
height 图片高度
url 图片oss地址

7.2.4. SoundElem

Field Description
uuid 唯一ID
soundPath 本地资源地址
sourceUrl oss地址
dataSize 音频大小
duration 音频时长

7.2.5. VideoElem

Field Description
videoPath 视频本地资源地址
videoUUID 视频唯一ID
videoUrl 视频oss地址
videoType 视频类型
videoSize 视频大小
duration 视频时长
snapshotPath 视频快照本地地址
snapshotUUID 视频快照唯一ID
snapshotSize 视频快照大小
snapshotUrl 视频快照oss地址
snapshotWidth 视频快照宽度
snapshotHeight 视频快照高度

7.2.6. FileElem

Field Description
filePath 文件本地资源地址
uuid 唯一ID
sourceUrl oss地址
fileName 文件名称
fileSize 文件大小

7.2.7. MergeElem

Field Description
title 合并消息标题
abstractList 摘要列表
multiMessage 合并消息列表

7.2.8. AtElem

Field Description
text 文本消息
atUserList @用户ID列表
isAtSelf 是否@自己

7.2.9. LocationElem

Field Description
description 描述
longitude 经度
latitude 纬度

7.2.10. CustomElem

Field Description
data 自定义消息字节数据
extension 自定义消息扩展字节数据
description 描述

7.2.11. QuoteElem

Field Description
quoteMessage 引用消息

7.3. 会话对象

class ConversationInfo {
    String conversationID;
    int conversationType; // [ConversationType]
    String userID;
    String groupID;
    String showName;
    String faceUrl;
    int recvMsgOpt;
    int unreadCount;
    Message latestMsg;
    int latestMsgSendTime;
    String draftText;
    int draftTimestamp;
    int isPinned; // pinned value is 1
}
Field Description
conversationID 会话ID
conversationType 会话类型 1:单聊 2:群聊
userID 会话对象用户ID
groupID 会话群聊ID
showName 会话对象(用户或群聊)名称
faceUrl 用户头像或群聊头像
recvMsgOpt 接收消息选项:
1:在线正常接收消息,离线时进行推送
2:不会接收到消息
3:在线正常接收消息,离线不会有推送
unreadCount 未读消息数量
latestMsg 最后一条消息 消息对象json字符串
latestMsgSendTime 最后一条消息发送时间(ns)
draftText 会话草稿
draftTimestamp 会话草稿设置时间
isPinned 是否置顶,1置顶

7.4. 已读消息回执

class HaveReadInfo {
    String uid;
    List<String> msgIDList;
    int readTime;
    int msgFrom;
    int contentType;
    int sessionType;
}
Field Description
uid 单聊对象的ID
contentType 消息类型: 101:文本消息 102:图片消息 103:语音消息 104:视频消息 105:文件消息 106:@消息 107:合并消息 108:转发消息 109:位置消息 110:自定义消息 111:撤回消息回执 112:C2C已读回执 113:正在输入状态
msgFrom 标识消息是用户级别还是系统级别 100:用户 200:系统
msgIDList 已读消息clientMsgID集合
readTime 已读时间
sessionType 会话类型 1:单聊 2:群聊

7.5. 群组信息对象

class GroupInfo {
    String groupID;
    String groupName;
    String notification;
    String introduction;
    String faceUrl;
    String ownerId;
    int createTime;
    int memberCount;
}
Field Description
groupID 群组ID
groupName 群组名称
notification 群公告
introduction 群介绍
faceUrl 群头像
ownerId 群主ID
createTime 群组创建时间
memberCount 群成员总数

7.6. 群组成员信息

class GroupMembersInfo {
    String groupID;
    String userId;
    int role;
    int joinTime;
    String nickName;
    String faceUrl;
    Object ext;
}
Field Description
groupID 群id
userId 用户id
role 用户的角色,0:普通成员 1:发起者 2:管理员
joinTime 加入时间
nickName 群昵称
faceUrl 头像
ext 扩展字段

7.7. 群申请信息

class GroupApplicationInfo {
    String id;
    String groupID;
    String fromUserID;
    String toUserID;
    int flag; // INIT = 0, REFUSE = -1, AGREE = 1
    String reqMsg;
    String handledMsg;
    int createTime;
    String fromUserNickName;
    String toUserNickName;
    String fromUserFaceURL;
    String toUserFaceURL;
    String handledUser;
    int type; //APPLICATION = 0, INVITE = 1
    int handleStatus; // UNHANDLED = 0, BY_OTHER = 1, BY_SELF = 2
    int handleResult; // REFUSE = 0, AGREE = 1
}
Field Description
groupID 群组ID
fromUserID 申请用户的ID
toUserID 接收用户的ID
flag 0:未处理,1:拒绝,2:同意
reqMsg 入群原因
handledMsg 处理反馈
createTime 申请事件
fromUserNickName 申请用户的昵称
toUserNickName 接收用户的昵称
fromUserFaceURL 申请用户的头像
toUserFaceURL 接收用户的头像
handledUser 处理人
type 0:申请进群, 1:邀请进群
handleStatus 0:未处理, 1:被其他人处理, 2:被自己处理
handleResult 0:拒绝,1:同意