You need to enable JavaScript to run this app.
导航
消息相关
最近更新时间:2024.05.16 10:55:02首次发布时间:2023.04.24 11:11:47

本文档提供消息相关的类型和接口使用说明。

客户端

API 接口详细文档参看 Android API 参考iOS API 参考Web API 参考微信小程序 API 参考

消息类型

BIMMessage 为 IMSDK 的消息内容承载类,在使用 IMSDK 的过程中会频繁的使用该类。
IMSDK 支持如下消息:

消息分类消息类型说明
文本消息BIM_MESSAGE_TYPE_TEXT普通文本消息
图片消息BIM_MESSAGE_TYPE_IMAGE图片消息,含原始图,缩略图
视频消息BIM_MESSAGE_TYPE_VIDEO视频文件以及视频封面图,最大不超过 50M
语音消息BIM_MESSAGE_TYPE_AUDIO语音文件,最大不超过 50M
文件消息BIM_MESSAGE_TYPE_FILE文件消息,最大不超过 50M
自定义消息BIM_MESSAGE_TYPE_CUSTOM开发者自定义字符串,IMSDK 透传,保存到本地
自定义透传消息BIM_MESSAGE_TYPE_P2P开发者自定义透传消息,IMSDK 透传,不保存到本地

创建消息

创建文本消息

使用 BIMClient 中的 createTextMessage 方法创建文本消息。

BIMMessage textMessage = BIMClient.getInstance().createTextMessage("消息内容");

创建图片消息

使用 BIMClient 中的 createImageMessage 方法创建图片消息,其中 path 为当前发送图片文件的本地路径。

BIMMessage imageMessage = BIMClient.getInstance().createImageMessage(path);

创建语音消息

使用 BIMClient 中的 createAudioMessage 方法创建语音消息,其中 path 为当前语音文件的本地路径。

BIMMessage audioMessage = BIMClient.getInstance().createAudioMessage(path);

创建视频消息

使用 BIMClient 中的 createVideoMessage 方法创建视频消息,其中 path 为当前视频文件的本地路径。

BIMMessage videoMessage = BIMClient.getInstance().createVideoMessage(path);

创建文件消息

使用 BIMClient 中的 createFileMessage 方法创建文件消息,其中 path 为当前文件的本地路径,uri 为当前文件本地 uri,path 和 uri 可以二选一使用(iOS 只有 path),推荐优先使用 path。

/**
 * 创建文件消息
 * @param uri      文件uri
 * @param path     文件路径
 * @param fileName 文件名称
 * @param length   文件大小
 * @return
 */
 BIMMessage fileMessage = BIMClient.getInstance().createFileMessage(uri, path, fileName, length);

创建自定义消息

使用 BIMClient 中的 createCustomMessage 方法创建文件消息,其中 data 参数为自定义消息内容,通常为 json 格式数据。

/**
 * 创建自定义消息
 * @param data 自定义消息内容
 * @return
 */
BIMMessage customMessage = BIMClient.getInstance().createCustomMessage(data);

发送消息

发送消息的方法在 BIMClient 中,使用 sendMessage 接口可实现,示例代码如下。

/**
 * @param message
 * @param conversationId 会话id
 * @param callback       回调
 */
BIMClient.getInstance().sendMessage(msg, conversationId, new BIMSendCallback() {

    @Override
    public void onAdd(BIMMessage message) {
        //媒体消息回调,方便媒体消息上屏
    }

    @Override
    public void onProgress(BIMMessage message, int progress) {
        //媒体消息回调,上传进度
    }

    @Override
    public void onSaved(BIMMessage bimMessage) {
       //媒体消息回调,消息已经入库
    }

    @Override
    public void onSuccess(BIMMessage bimMessage) {
       //发送成功
    }

    @Override
    public void onAsync(BIMMessage bimMessage, boolean isUpdate) {
        //发送风控回调
    }

    @Override
    public void onError(BIMMessage bimMessage, int code, String desc) {
        //发送失败
    }
})

接收消息

使用 BIMClient 中的 addMessageListener 设置消息监听,可通过 bimMessage.getMsgType() 获取消息类型属性。

BIMClient.getInstance().addMessageListener(new BIMMessageListener() {
    @Override
    public void onReceiveMessage(BIMMessage bimMessage) {
        //收到消息回调
    }

    @Override
    public void onSendMessage(BIMMessage bimMessage) {
        //本地发出消息回调
    }

    @Override
    public void onDeleteMessage(BIMMessage bimMessage) {
        //删除消息回调
    }

    @Override
    public void onRecallMessage(BIMMessage bimMessage) {
        //撤回消息回调
    }

    @Override
    public void onUpdateMessage(BIMMessage bimMessage) {
        //消息更新回调
    }

    @Override
    public void onReceiveMessagesReadReceipt(List<BIMMessageReadReceipt> receiptList) {
        //收到消息已读回执回调
    }
});

自定义透传消息

创建自定义透传消息

使用 createP2PMessage 接口创建自定义透传消息。(Web/小程序 SDK 直接调用「发送自定义透传消息」接口)

BIMClient.getInstance().createP2PMessage(content);
    

发送自定义透传消息

使用 sendP2PMessage 接口发送自定义透传消息。成功调用后,会话用户会收到自定义透传消息的事件监听,参看 自定义透传消息监听

// 用户纬度,给会话内指定用户发送自定义透传消息
        // userIdList为接收自定义透传消息的用户列表
        BIMClient.getInstance().sendP2PMessage(message, conversationId, userIdList, new BIMSimpleCallback() {
            @Override
            public void onSuccess() {
                
            }

            @Override
            public void onFailed(BIMErrorCode code) {

            }
        });
        // 会话纬度,给会话内所有用户发送自定义透传消息
        BIMClient.getInstance().sendP2PMessage(message, conversationId, new BIMSimpleCallback() {
            @Override
            public void onSuccess() {
                //成功
            }

            @Override
            public void onFailed(BIMErrorCode code) {
                //失败
            }
        });     

自定义透传消息监听

添加自定义透传消息监听,监听发送、收到自定义透传消息事件。

BIMP2PMessageListener pMessageListener = new BIMP2PMessageListener() {
            @Override
            public void onReceiveP2PMessage(BIMMessage p2pMessage) {
                    //收到 p2p 消息
            }

            @Override
            public void onSendP2PMessage(BIMMessage p2pMessage) {
                    //发送 p2p 消息
            }
        };
        BIMClient.getInstance().addP2PMessageListener(listener);
        BIMClient.getInstance().removeP2PMessageListener(listener);
    

已读回执

版本 v1.13.0 以上支持消息已读回执。消息已读回执是指消息发送后,接收方查看消息后可以发送自己已读给发送端,示例代码如下。

消息是否已回执

他人消息是否已回执可以通过 BIMMessage 中的 isSendReadReceipt 接口获取。(Web/小程序 SDK 需通过「拉取消息已读回执信息」接口获取)

boolean isReadReceipt = bimMessage.isSendReadReceipt();
    

消息已读人数

当前用户发送消息已回执/未回执的人数可以通过 BIMMessage 中的 getReadCountgetUnReadCount 接口获取,示例代码如下。(Web/小程序 SDK 需通过「拉取消息已读回执信息」接口获取)

int readCount = bimMessage.getReadCount(); // 已回执人数
             int unReadCount = bimMessage.getUnReadCount(); // 未回执人数
    

拉取消息已读回执信息

可以通过 getMessagesReadReceipt 批量获取消息的已读回执信息,示例代码如下。

BIMClient.getInstance().getMessagesReadReceipt(Collections.singletonList(message), new BIMResultCallback<List<BIMMessageReadReceipt>>() {
            @Override
            public void onSuccess(List<BIMMessageReadReceipt> bimMessageReadReceipts) {
              
            }

            @Override
            public void onFailed(BIMErrorCode code) {
             
            }
        });

发送消息已读回执

可以通过 sendMessageReadReceipts 批量发送消息已读回执,注意需要过滤掉当前用户发送的消息,以及已经回执过的消息。

BIMClient.getInstance().sendMessageReadReceipts(bimMessageList, new BIMSimpleCallback() {
                @Override
                public void onSuccess() {

                }

                @Override
                public void onFailed(BIMErrorCode code) {

                }
            });

已读回执监听

已读回执监听可使用 BIMClient 中的 addMessageListener 设置消息监听,使用 BIMMessageListener 移除消息监听。

BIMMessageListener messageListener = new BIMMessageListener() {
            // ... 其他回调
            @Override
            public void onReceiveReadReceipt(List<BIMReadReceipt> readReceiptList) {
                // 收到消息已读回执回调
            }
        };
        //添加消息监听
        BIMClient.getInstance().addMessageListener(messageListener);
        //移除消息监听
        BIMClient.getInstance().removeMessageListener(messageListener);

发送会话已读回执 (仅支持单聊)

进入会话页面,可通过发送会话已读回执标记会话所有消息已读。

// 会话已读回执仅支持单聊
if (bimConversation.getConversationType() == BIMConversationType.BIM_CONVERSATION_TYPE_ONE_CHAT) {
    BIMClient.getInstance().markConversationMessagesRead(bimConversation.getConversationID(), new BIMSimpleCallback() {
        @Override
        public void onSuccess() {
            // 发送成功
        }
    
        @Override
        public void onFailed(BIMErrorCode code) {
            // 发送失败
        }
    });
}

会话已读回执通知(仅支持单聊)

使用 BIMClient 中的 addConversationListener 设置消息已读回执监听。

BIMClient.getInstance().addConversationListener(new BIMConversationListListener() {
    // ... 其他回调
    
    @Override
    public void onConversationRead(String conversationId, long fromUid) {
        //收到会话已读回执回调,刷新UI
    }
});
服务端

当你需要通过调用服务端接口 SendMessageUserBroadcast 接口向客户端发送消息时,你需要传入 MsgTypeContent 来构建一条信息。
你需要将消息内容按照以下 Json 格式进行构建,并将 Json 内容转换成 String 格式后传入 SendMessage.Content 中。

文字消息

MsgType

MsgType = 10001

Content

{
    "text":"文字消息" // 文本
}

图片消息

MsgType

MsgType = 10003

Content

{
    "__files":{//媒体列表
        "media":{//媒体信息
            "displayType":"media",//固定值为 media
            "mime":"image/jpeg",//mimetype 格式
            "length":5313,//文件大小,单位为 b
            "fileName":"Your_file.jpeg",//文件名称
            "type":"jpeg",//文件类型
            "ext":{
                "s:file_ext_key_source_app_id":"000000",    //AppId
                "s:file_ext_key_file_name":"Your_file.jpeg",//文件名称
                "s:file_ext_key_original_height":"200",    //原图高
                "s:file_ext_key_original_width":"100",    //原图宽
                "s:file_ext_key_thumb_height":"100",      //缩略图高
                "s:file_ext_key_thumb_width":"50", //缩略图宽
                "s:file_ext_key_preview_width":"100",//中图宽
                "s:file_ext_key_preview_height":"200",//中图宽
                "s:file_ext_key_preview_url":"https://xxx.xxx",//中图url
                "s:file_ext_key_thumb_url":"https://xxx.xxx.xxx"//缩略图url
            },
            "remoteURL":"https://xxx.xxx.xxxxx"//原图url
        }
    }
}

视频消息

MsgType

MsgType = 10004

Content

{
    "__files":{//媒体列表
        "media":{//媒体信息
            "displayType":"media",//固定值为 media
            "mime":"video/mp4",//mimetype 格式
            "length":13494185,//文件大小,单位为 b
            "fileName":"Your_file.mp4",//文件名称
            "type":"mp4",//文件类型
            "ext":{
                "s:file_ext_key_source_app_id":"000000",//AppId
                "s:file_ext_key_file_name":"Your_file.mp4",//文件名称
                "s:file_ext_key_video_duration":"10",//视频时长,单位为 s。
                "s:file_ext_key_video_height":"200",//视频高,单位为 px。
                "s:file_ext_key_video_width":"100",//视频宽,单位为 px。
                "s:file_ext_key_video_cover_url":"https://xxx.xxx"//封面url
            },
            //视频url
            "remoteURL":"https://xxx.xxx"
        }
    }
}

文件消息

MsgType

MsgType = 10005

Content

{
    "__files":{//媒体列表
        "media":{//媒体信息
            "displayType":"media",//固定值为 media
            "mime":"string",//mimetype 格式
            "length":9410,//文件大小,单位为 b
            "fileName":"Your_file.v",//文件名称
            "type":"v",//文件类型
            "ext":{
                "s:file_ext_key_source_app_id":"000000",//AppId
                "s:file_ext_key_file_name":"Your_file.v"//文件名称
            },
            //文件 url
            "remoteURL":"https://xxx.xxx"
        }
    }
}

语音消息

MsgType

MsgType = 10006

Content

{
    "__files":{//媒体列表
        "media":{//媒体信息
            "displayType":"media",//固定值为 media
            "mime":"audio/*",//mimetype 格式
            "length":328364,//文件大小,单位为 b
            "fileName":"Your_file.wav",//文件名称
            "type":"wav",//文件类型
            "ext":{
                "s:file_ext_key_source_app_id":"000000",//AppId
                "s:file_ext_key_file_name":"Your_file.wav",//文件名称
                "s:file_ext_key_audio_duration":"3.608"//语音时长,单位为 s
            },
            //语音url
            "remoteURL":"xxx.xxx"
        }
    }
}

自定义消息

MsgType

MsgType = 10012

Content

IM 未对自定义消息 Content 字段进行约定,你可以自行构建渲染。