- 实现了聊天消息发送功能,支持文本、图片、视频、音频、文件等多种消息类型 - 集成了文件上传下载功能,支持多媒体文件的传输和管理 - 添加了群组管理功能,包括创建群组、成员管理、权限控制等操作 - 实现了好友系统,支持好友添加、删除、分组等功能 - 集成了黑名单管理,提供用户屏蔽和解除屏蔽功能 - 添加了会话管理功能,支持对话列表、未读消息统计等 - 实现了历史消息查询和搜索功能 - 添加了实时连接状态管理和自动重连机制
3.6 KiB
3.6 KiB
React Native IM 接入
基于 @xuqm/rn-im 模块实现即时通讯功能,使用 WatermelonDB 进行本地消息存储。
初始化与登录
初始化
import { XuqmSDK } from '@xuqm/rn-common'
await XuqmSDK.initialize({
appKey: 'your_app_key',
logLevel: __DEV__ ? 'debug' : 'warn',
})
登录
import { XuqmSDK } from '@xuqm/rn-common'
await XuqmSDK.login({
userId: 'user_001',
userSig: 'your_user_sig_jwt',
})
如果集成了
rn-im,XuqmSDK.login会自动触发ImSDK连接,业务侧无需单独调用ImSDK.login。
消息收发
监听实时消息
import { ImSDK } from '@xuqm/rn-im'
ImSDK.addEventListener('message', (msg) => {
console.log('收到消息:', msg.msgType, msg.content)
})
ImSDK.addEventListener('read', (msg) => {
console.log('已读回执:', msg.id)
})
ImSDK.addEventListener('revoke', (data) => {
console.log('消息被撤回:', data.msgId)
})
发送文本消息
const msg = await ImSDK.sendMessage(
'user_002', // toId
'SINGLE', // chatType: 'SINGLE' | 'GROUP'
'TEXT', // msgType
'Hello!' // content
)
发送图片
const msg = await ImSDK.sendImageMessage(
'user_002',
'SINGLE',
'/path/to/image.jpg', // 本地 URI
800, // 宽
600 // 高
)
获取历史消息
// 单聊历史
const history = await ImSDK.fetchHistory('user_002', page, size)
// 群历史
const groupHistory = await ImSDK.fetchGroupHistory('group_xxx', page, size)
WatermelonDB 本地存储
rn-im 使用 WatermelonDB(SQLite)存储本地消息,按 appKey + userId 自动隔离。
import { ImDatabase } from '@xuqm/rn-im'
// 消息搜索(本地)
const params: MessageSearchParams = {
keyword: '会议',
toId: 'user_002',
chatType: 'SINGLE',
msgTypes: ['TEXT'],
limit: 20,
}
const results = await ImSDK.searchMessages(params)
群聊
// 创建群
const group = await ImSDK.createGroup('项目讨论', ['user_002', 'user_003'])
// 群列表
const groups = await ImSDK.listGroups()
// 添加成员
await ImSDK.addGroupMember('group_xxx', 'user_004')
// 移除成员
await ImSDK.removeGroupMember('group_xxx', 'user_004')
// 退出群聊
await ImSDK.leaveGroup('group_xxx')
详见 RN 群聊文档 →
会话列表
// 订阅会话变化
const unsub = ImSDK.subscribeConversations((conversations) => {
console.log(conversations)
})
// 置顶
await ImSDK.setConversationPinned('user_002', 'SINGLE', true)
// 免打扰
await ImSDK.setConversationMuted('group_xxx', 'GROUP', true)
// 标记已读
await ImSDK.markRead('user_002')
离线消息同步
// 查询离线消息数量(示例)
const count = await ImSDK.offlineMessageCount()
// 同步离线消息(示例)
const messages = await ImSDK.syncOfflineMessages()
断开连接
ImSDK.disconnect()
类型参考
interface ImMessage {
id: string
fromId: string
toId: string
chatType: 'SINGLE' | 'GROUP'
msgType: 'TEXT' | 'IMAGE' | 'AUDIO' | 'VIDEO' | 'FILE' |
'LOCATION' | 'NOTIFY' | 'CUSTOM' | 'RICH_TEXT' |
'CALL_AUDIO' | 'CALL_VIDEO' | 'FORWARD' | 'REVOKED'
content: string
status: 'SENDING' | 'SENT' | 'DELIVERED' | 'READ' | 'FAILED' | 'REVOKED'
createdAt: number
}
interface ConversationData {
targetId: string
chatType: 'SINGLE' | 'GROUP'
lastMsgContent: string
lastMsgType: string
lastMsgTime: number
unreadCount: number
isMuted: boolean
isPinned: boolean
}