云端历史消息查询
更新时间: 2024/11/29 10:53:42
网易云信 IM 支持用户查询云端历史消息功能,包括单聊、群聊、聊天室云端历史消息,以及服务端会话列表。
查询单聊云端历史消息
功能描述
查询存储在网易云信服务器中的单人聊天历史消息,只能查询在保存时间范围内的消息。
- 根据时间段查询点对点消息,每次最多返回 100 条。
- 不提供分页支持,第三方需要根据时间段来查询。
begintime
需要早于endtime
,否则会返回{"desc": "bad time", "code": 414}
。
使用限制
单个应用默认最高调用频率请参考 频控说明。
请求 URL
POST https://api.netease.im/nimserver/history/querySessionMsg.action HTTP/1.1
Content-Type: application/x-www-form-urlencoded;charset=utf-8
请求参数
- POST 请求中 Headers 的设置请参考 API 调用方式。
- POST 请求中 Body 的设置如下:
参数 | 类型 | 必填 | 说明 |
---|---|---|---|
from | String | 是 | 发送者账号 ID(`accid`) |
to | String | 是 | 接收者账号 ID(`accid`) |
begintime | String | 是 | 开始时间,毫秒级 |
endtime | String | 是 | 截止时间,毫秒级 |
limit | int | 是 | 本次查询的消息条数上限(最多 100 条),小于等于 0,或者大于 100,会提示参数错误 |
reverse | int | 否 | 1 按时间正序排列,2 按时间降序排列。其它返回参数 414 错误.默认是按降序排列,即时间戳最晚的消息排在最前面。 |
type | String | 否 | 查询指定的多个消息类型,类型之间用","分割,不设置该参数则查询全部类型消息格式示例:0,1,2,3
类型支持:0:文本,1:图片,2:语音,3:视频,4:地理位置,5:通知,6:文件,10:提示,11:Robot,100:自定义 |
includeNoSenseMsg | String | 否 | 查询结果中是否需要包含无感知消息,true:包含,false:不包含,默认为 false 无感知消息具体包括:
|
excludeMsgid | String | 否 | 结束查询的最后一条消息的 msgid(不包含在查询结果中),用于定位锚点 |
请求示例
cURLcurl -X POST -H "AppKey: go9d***3mgq3" -H "Nonce: 4tg***23t" -H "CurTime: 1443592222" -H "CheckSum: 9e9d***c55583f86" -H "Content-Type: application/x-www-form-urlencoded" -d 'begintime=1443599631111&endtime=1443599639999&from=zhangsan&to=lisi&limit=50' 'https://api.netease.im/nimserver/history/querySessionMsg.action'
返回示例
JSON"Content-Type": "application/json; charset=utf-8"
{
"code":200,
"size":xxx,//总共消息条数
"msgs":[msg1,msg2,···,msgn] //消息集合,JSONArray
}
查询返回的消息示例参考 历史消息查询返回的消息格式说明。
状态码
该接口在 HTTPS Body 中返回请求的状态码,状态码详情请参考 状态码。
查询群聊云端历史消息
功能描述
查询存储在网易云信服务器中的群聊历史消息,只能查询在保存时间范围内的消息。
- 根据时间段查询群消息,每次最多返回 100 条。
- 不提供分页支持,第三方需要根据时间段来查询。
begintime
需要早于endtime
,否则会返回{"desc": "bad time", "code": 414}。
使用限制
单个应用默认最高调用频率请参考 频控说明。
请求 URL
POST https://api.netease.im/nimserver/history/queryTeamMsg.action HTTP/1.1
Content-Type: application/x-www-form-urlencoded;charset=utf-8
请求参数
- POST 请求中 Headers 的设置请参考 API 调用方式。
- POST 请求中 Body 的设置如下:
参数 | 类型 | 必填 | 说明 |
---|---|---|---|
tid | String | 是 | 群 ID |
accid | String | 是 | 查询用户对应的账号 ID(`accid`). |
begintime | String | 是 | 开始时间,毫秒级 |
endtime | String | 是 | 截止时间,毫秒级 |
limit | int | 是 | 本次查询的消息条数上限(最多 100 条),小于等于 0,或者大于 100,会提示参数错误 |
reverse | int | 否 | 1 按时间正序排列,2 按时间降序排列。其它返回参数 414 错误。默认是按降序排列,即时间戳最晚的消息排在最前面。 |
type | String | 否 | 查询指定的多个消息类型,类型之间用","分割,不设置该参数则查询全部类型消息格式示例:0,1,2,3
类型支持:0:文本,1:图片,2:语音,3:视频,4:地理位置,5:通知,6:文件,10:提示,11:Robot,100:自定义 |
checkTeamValid | Boolean | 否 | true(默认值):表示需要检查群是否有效,accid 是否为有效的群成员。设置为 false 则仅检测群是否存在,accid 是否曾经为群成员。 |
includeNoSenseMsg | String | 否 | 查询结果中是否需要包含无感知消息,true:包含,false:不包含,默认为 false 无感知消息具体包括:
|
excludeMsgid | String | 否 | 结束查询的最后一条消息的 msgid(不包含在查询结果中),用于定位锚点 |
请求示例
cURLcurl -X POST -H "AppKey: go9***03mgq3" -H "Nonce: 4tg***23t" -H "CurTime: 1443592222" -H "CheckSum: 9e9d***583f86" -H "Content-Type: application/x-www-form-urlencoded" -d 'begintime=1443599631111&endtime=1443599639999&tid=1513535&accid=zhangsan&limit=50' 'https://api.netease.im/nimserver/history/queryTeamMsg.action'
返回示例
JSON"Content-Type": "application/json; charset=utf-8"
{
"code":200,
"size":xxx,//总共消息条数
"msgs":[msg1,msg2,···,msgn] //消息集合,JSONArray。
}
查询返回的消息示例参考 历史消息查询返回的消息格式说明。
状态码
接口在 HTTPS Body 中返回请求的状态码,状态码详情请参考 状态码。
查询聊天室云端历史消息
功能描述
查询存储在网易云信服务器中的聊天室历史消息。
使用限制
单个应用默认最高调用频率:1200 次/分。如超限,将被屏蔽 1 分钟。
请求 URL
POST https://api.netease.im/nimserver/history/queryChatroomMsg.action HTTP/1.1
Content-Type: application/x-www-form-urlencoded;charset=utf-8
请求中 Headers 的设置请参考 API 调用方式
请求参数
- POST 请求中 Headers 的设置请参考 API 调用方式。
- POST 请求中 Body 的设置如下:
参数 | 类型 | 必填 | 说明 |
---|---|---|---|
roomid | long | 是 | 聊天室 ID |
accid | String | 是 | 用户账号 |
timetag | long | 是 | 查询的时间戳锚点,13 位。reverse=1 时 timetag 为起始时间戳,reverse=2 时 timetag 为终止时间戳 |
limit | int | 是 | 本次查询的消息条数上限(最多 200 条),小于等于 0,或者大于 200,会提示参数错误 |
reverse | int | 否 | 1 按时间正序排列,2 按时间降序排列。其它返回参数 414 错误。默认是 2 按时间降序排列 |
type | String | 否 | 查询指定的多个消息类型,类型之间用","分割,不设置该参数则查询全部类型消息。 格式示例:0,1,2,3 支持的消息类型:0:文本,1:图片,2:语音,3:视频,4:地理位置,5:通知,6:文件,10:提示,11:智能机器人消息,100:自定义消息。用英文逗号分隔。 |
请求示例
cURLcurl -X POST -H "AppKey: go9dnk4***gq3" -H "Nonce: 12345" -H "CurTime: 1459154905" -H "CheckSum: 8d3ef0***75d906e48e75fc9d3" -H "Content-Type: application/x-www-form-urlencoded" -d 'roomid=123456&accid=zhangsan&timetag=1471234567812&limit=20&reverse=2' "https://api.netease.im/nimserver/history/queryChatroomMsg.action"
返回示例
JSON"Content-Type": "application/json; charset=utf-8"
{
"code":200,
"size":xxx,//总共消息条数
"msgs":[msg1,msg2,···,msgn] //消息集合,JSONArray。
}
查询返回的消息示例参考 历史消息查询返回的消息格式说明。
状态码
接口在 HTTPS Body 中返回请求的状态码,状态码详情请参考 状态码。
删除聊天室云端历史消息
使用限制
单个应用默认最高调用频率请参考 频控说明。
请求 URL
POST https://api.netease.im/nimserver/chatroom/deleteHistoryMessage.action HTTP/1.1
Content-Type: application/x-www-form-urlencoded;charset=utf-8
请求参数
- POST 请求中 Headers 的设置请参考 API 调用方式。
- POST 请求中 Body 的设置如下:
参数 | 类型 | 必填 | 说明 |
---|---|---|---|
roomid | long | 是 | 聊天室 ID |
fromAcc | String | 是 | 消息发送者的账号 ID(`accid`) |
msgTimetag | long | 是 | 消息的时间戳,单位毫秒,应该拿到原始消息中的时间戳为参数 |
请求示例
cURLcurl -X POST -H "AppKey: go9***3mgq3" -H "Nonce: 12345" -H "CurTime: 1459154905" -H "CheckSum: 8d3ef***6e48e75fc9d3" -H "Content-Type: application/x-www-form-urlencoded" -d 'roomid=123456&fromAcc=zhangsan&msgTimetag=1491234567812' "https://api.netease.im/nimserver/chatroom/deleteHistoryMessage.action"
返回示例
JSON"Content-Type": "application/json; charset=utf-8"
{
"code":200
}
状态码
接口在 HTTPS Body 中返回请求的状态码,状态码详情请参考 状态码。
查询服务端会话列表
功能描述
查询服务端会话列表,需要先开通服务端会话列表功能。
使用限制
单个应用默认最高调用频率请参考 频控说明。
请求 URL
POST https://api.netease.im/nimserver/history/querySessionList.action HTTP/1.1
Content-Type: application/x-www-form-urlencoded;charset=utf-8
请求参数
- POST 请求中 Headers 的设置请参考 API 调用方式。
- POST 请求中 Body 的设置如下:
参数 | 类型 | 必填 | 说明 |
---|---|---|---|
accid | String | 是 | 账号 |
minTimestamp | long | 否 | 查询的最小时间戳,单位毫秒,默认 0 |
maxTimestamp | long | 否 | 查询的最大时间戳,单位毫秒,默认当前时间戳 |
limit | int | 否 | 最大 100,默认 100 |
needLastMsg | int | 否 | 是否需要同步返回最后一条消息,0 表示不需要,1 表示需要,默认不需要 |
请求示例
cURLcurl -X POST -H "appkey: fe416***ad2547" -H "nonce: 12345" -H "curtime: 1459154905" -H "checksum: 8d3ef***8e75fc9d3" -H "Content-Type: application/x-www-form-urlencoded" -d 'accid=acc01' "https://api.netease.im/nimserver/history/querySessionList.action"
返回示例
JSON"Content-Type": "application/json; charset=utf-8"
{
"code": 200,
"data": {
"sessions": [
{
"lastMsgType": "RECALL", //表示最后一条消息是撤回
"updateTime": 1627895970387,
"lastMsg": {
"deleteMsgIdClient": "39468de03f65059dee60c28558aa1b92", //被撤回消息的消息 ID(客户端)
"deleteMsgCreateTime": 1627895944689, //被撤回消息的发送时间
"from": "acc02", //撤回操作者
"time": 1627895970387, //撤回操作时间
"deleteMsgIdServer": "10252224" //被撤回消息的消息 ID(服务器)
},
"sessionType": 1, //会话类型,1 表示点对点,2 表示群,3 表示超大群,其中超大群最后一条消息暂不支持撤回
"accid": "accid01" //如果是点对点会话,则包括账号 ID(`accid`) 字段。如果是群和超大群,则包括 tid 字段
},
{
"lastMsgType": "MESSAGE", //表示最后一条消息是消息
"updateTime": 1627895899222,
"lastMsg": {
"msgIdClient": "742b887b50576e3562994bb616ecf4f0", //消息 ID(客户端)
"fromClientType": "WEB", //消息发送者客户端类型
"from": "acc03", //消息发送者
"time": "1627895899222", //消息发送时间
"body": "嘿哈嘿哈 123", //消息内容,包括 body、attach、ext 三个字段,本例子仅包含了 body 字段
"type": 0,
"msgIdServer": 10252222 //消息 ID(服务器)
},
"sessionType": 2,
"tid": 123 //如果是点对点会话,则包括账号 ID(`accid`) 字段。如果是群和超大群,则包括 tid 字段
}
],
"hasMore": false
}
}
状态码
该接口在 HTTPS Body 中返回请求的状态码,状态码详情请参考 状态码。
返回的历史消息消息格式
msgid
(Long 类型)为消息的服务端 ID,msgidclient
(String 类型)为消息的客户端 ID。- 当消息为聊天室消息时,此时只有
msgid
,没有msgidclient
,且msgid
为 String 类型,即"msgid": "d864"
。
普通文本消息
JSON{
"from":"test1",
"msgid":792478,
"sendtime":1430967883307,
"type":0,//文本消息类型
"fromclienttype": 2, //1:android、2:iOS、4:PC、16:WEB、32:REST、64:MAC
"msgidclient": "3bfd9660665a14bce4ec95e1b1d3afed",
"body":{
"msg": "哈哈哈" //消息内容
}
}
图片消息
JSON{
"from":"test1",
"msgid":792502,
"sendtime":1430978396680, //发送时间 ms
"type":1, //图片类型消息
"fromclienttype": 2, //1:android、2:iOS、4:PC、16:WEB、32:REST、64:MAC
"msgidclient": "3bfd9660665a14bce4ec95e1b1d3afed",
"body":{
"name":"图片发送于 2015-05-07 13:59", //图片 name
"md5":"9894907e4ad9de4678091277509361f7", //图片文件 md5
"url":"http://nimtest.nos.netease.com/cbc500e8-e19c-4b0f-834b-c32d4dc1075e", //生成的 url
"ext":"jpg", //图片后缀
"w":6814, //宽,单位为像素
"h":2332, //高,单位为像素
"size":388245 //图片大小
}
}
语音消息
JSON{
"from":"test1",
"msgid":792479,
"sendtime":1430967899646, //发送时间 ms
"type":2, //语音类型消息
"fromclienttype": 2, //1:android、2:iOS、4:PC、16:WEB、32:REST、64:MAC
"msgidclient": "3bfd9660665a14bce4ec95e1b1d3afed",
"body":{
"dur":4551, //语音持续时长 ms
"md5":"87b94a090dec5c58f242b7132a530a01", //md5
"url":"http://nimtest.nos.netease.com/a2583322-413d-4653-9a70-9cabdfc7f5f9", //生成的 url
"ext":"aac", //语音消息格式,只能是 aac 格式
"size":16420 //语音文件大小
}
}
视频消息
JSON{
"from":"test1",
"msgid":792505,
"sendtime":1430978424249, //发送时间 ms
"type":3 //视频类型消息
"fromclienttype": 2, //1:android、2:iOS、4:PC、16:WEB、32:REST、64:MAC
"msgidclient": "3bfd9660665a14bce4ec95e1b1d3afed",
"body":{
"dur":8003, //视频持续时长 ms
"md5":"da2cef3e5663ee9c3547ef5d127f7e3e", //md5
"url":"http://nimtest.nos.netease.com/21f34447-e9ac-4871-91ad-d9f03af20412", //生成的 url
"w":360, //宽
"h":480, //高
"ext":"mp4", //视频格式
"size":16420 //视频文件大小
}
}
地理位置消息
JSON{
"from":"test1",
"msgid":792501,
"sendtime":1430978381896, //发送时间 ms
"type":4, //地理位置类型消息
"fromclienttype": 2, //1:android、2:iOS、4:PC、16:WEB、32:REST、64:MAC
"msgidclient": "3bfd9660665a14bce4ec95e1b1d3afed",
"body":{
"title":"中国 浙江省 杭州市 网商路 599 号", //地理位置 title
"lng":120.1908686708565, // 经度
"lat":30.18704515647036 // 纬度
}
}
文件消息
JSON{
"from":"test1",
"msgid":7925061,
"sendtime":1430978435894, //发送时间 ms
"type":6, //文件消息
"fromclienttype": 2, //1:android、2:iOS、4:PC、16:WEB、32:REST、64:MAC
"msgidclient": "3bfd9660665a14bce4ec95e1b1d3afed",
"body":{
"name":"BlizzardReg.ttf", //文件名
"md5":"79d62a35fa3d34c367b20c66afc2a500", //文件 MD5
"url":"http://nimtest.nos.netease.com/08c9859d-183f-4daa-9904-d6cacb51c95b", //文件 URL
"ext":"ttf", //文件后缀类型
"size":91680 //大小
}
}
自定义消息
JSON{
"from":"test1",
"msgid":792506,
"sendtime":1430978435894, //发送时间 ms
"type":100, //第三方自定义消息
"fromclienttype": 2, //1:android、2:iOS、4:PC、16:WEB、32:REST、64:MAC
"msgidclient": "3bfd9660665a14bce4ec95e1b1d3afed",
"body":{ //自定义的内容,需要符合 json 格式
…
}
}
群通知
JSON{
"msgid ":278703112201,
"from":"t4", //通知发起者
"sendtime":1430978435894, //发送时间 ms
"type":5, //群 notifycation 通知
"fromclienttype": 2, //1:android、2:iOS、4:PC、16:WEB、32:REST、64:MAC
"msgidclient": "3bfd9660665a14bce4ec95e1b1d3afed",
"body":{
"tid":4153, //群 ID
"tname":"key1", //群名称 (某些操作会有)
"ope":1, //notify 通知类型 (0:群拉人,1:群踢人,2:退出群,3:群信息更新,4:群解散,5:申请加入群成功,6:退出并移交群主,7:增加管理员,8:删除管理员,9:接受邀请进群,10:禁言群成员)
"accids":["t2"], //被操作的对象 (群成员操作时才有)
"intro": "群介绍", //(ope=3 时群信息修改项)
"announcement": "群公告", //(ope=3 时群信息修改项)
"joinmode":1, //加入群的模式 0 不需要认证,1 需要认证 ,(ope=3 时群信息修改项)
"config": "第三方服务器配制修改项",//(ope=3 时群信息修改项)
"updatetime":1432804852021 //通知后台更新时间 (群操作时有)
}
}
聊天室通知
JSON{
"msgid": "94b58bff-95ec-4cf9-91bd-4f6933d0ac3a",
"from": "user01",
"type": 5,
"fromclienttype": 16, //1:android、2:iOS、4:PC、16:WEB、32:REST、64:MAC
"sendtime": 1567502401139,
"body": {
"id": 301, //301: 成员进入聊天室,302: 成员离开聊天室,303: 成员被加黑,304: 成员被取消黑名单,305: 成员被设置禁言,306: 成员被取消禁言,307: 设置为管理员,308: 取消管理员,309: 成员设定为固定成员,310: 成员取消固定成员,312: 聊天室信息更新,313: 成员被踢,314: 新增临时禁言,315: 主动解除临时禁言,316: 成员更新聊天室内的角色信息,317: 麦序队列中有变更,318: 聊天室禁言,319: 聊天室解除禁言状态,320: 麦序队列中有批量变更
"data": {
"opeNick": "昵称 01",
"operator": "user01",
"target": ["user01"],
"tarNick": ["昵称 01"],
"ext": "自定义扩展信息"
}
}
}
此文档是否对你有帮助?