uniapp 集成腾讯云 IM 消息搜索功能

news2025/6/7 14:57:44

UniApp 集成腾讯云 IM 消息搜索功能实战指南

一、功能实现原理

腾讯云 IM 通过 消息漫游 + 服务端搜索接口 实现消息检索,核心机制如下:

  1. 数据存储:消息默认存储7天(可扩展至30天)
  2. 索引构建:基于消息内容自动建立倒排索引
  3. 检索接口:提供关键词匹配、时间范围、发送者等多维度查询
  4. 结果排序:按消息时间戳倒序排列

二、核心实现步骤

1. 初始化搜索模块

// services/search.js
import { initIM } from './im'

const tim = initIM()

// 配置搜索参数
const SEARCH_CONFIG = {
  MAX_KEYWORD_LENGTH: 30,    // 最大关键词长度
  DEFAULT_PAGE_SIZE: 20,     // 默认分页大小
  MAX_HISTORY_DAYS: 7        // 最大历史查询天数
}

// 创建搜索实例
export function createSearchEngine(options) {
  return {
    conversationID: options.conversationID,
    keyword: '',
    timeRange: {
      startTime: Date.now() - 7 * 24 * 3600 * 1000,
      endTime: Date.now()
    },
    page: 1,
    pageSize: SEARCH_CONFIG.DEFAULT_PAGE_SIZE
  }
}

2. 执行消息搜索

export async function executeSearch(engine) {
  const tim = initIM()
  
  try {
    const res = await tim.getMessageList({
      conversationID: engine.conversationID,
      keyword: engine.keyword,
      nextSeq: engine.page === 1 ? 0 : engine.nextSeq,
      count: engine.pageSize
    })

    return {
      messages: res.data.messageList || [],
      hasNext: res.data.isCompleted === 0,
      nextSeq: res.data.nextSeq
    }
  } catch (error) {
    console.error('搜索失败:', error)
    throw new Error('消息搜索失败,请检查网络')
  }
}

3. 搜索结果渲染

<template>
  <view class="search-results">
    <scroll-view 
      scroll-y
      @scrolltolower="loadMore"
    >
      <view 
        v-for="(msg, index) in results"
        :key="msg.clientMsgID"
        class="search-item"
      >
        <view class="highlight-text">
          {{ msg.payload.text.replace(
            new RegExp(engine.keyword, 'gi'), 
            (match) => `<mark>${match}</mark>`
          ) }}
        </view>
        <view class="meta-info">
          {{ formatTime(msg.time) }} - {{ msg.from }}
        </view>
      </view>
      
      <view v-if="loading" class="loading-tip">
        加载中...
      </view>
      
      <view v-if="!hasNext" class="end-tip">
        没有更多结果了
      </view>
    </scroll-view>
  </view>
</template>

<script>
export default {
  data() {
    return {
      engine: createSearchEngine({
        conversationID: 'current_conv_id'
      }),
      results: [],
      loading: false,
      hasNext: true
    }
  },
  methods: {
    async loadMore() {
      if (this.loading || !this.hasNext) return
      
      this.loading = true
      const res = await executeSearch(this.engine)
      this.results = [...this.results, ...res.messages]
      this.hasNext = res.hasNext
      this.loading = false
    }
  }
}
</script>

三、关键问题处理

1. 性能优化策略

// 防抖搜索(输入框场景)
let searchDebounce = null

export function debouncedSearch(engine, callback) {
  clearTimeout(searchDebounce)
  
  searchDebounce = setTimeout(async () => {
    engine.page = 1
    const res = await executeSearch(engine)
    callback(res.messages, res.hasNext)
  }, 300) // 300ms防抖
}

2. 复杂查询构建

// 高级查询构造器
export function buildAdvancedQuery(options) {
  const tim = initIM()
  
  return {
    conversationID: options.convID,
    keyword: options.keyword || '',
    filter: {
      fromAccount: options.from || [],
      timeRange: options.timeRange || {
        startTime: Date.now() - 7 * 24 * 3600 * 1000,
        endTime: Date.now()
      }
    },
    pageIndex: options.page || 1,
    pageSize: options.pageSize || 20
  }
}

// 使用示例
const query = buildAdvancedQuery({
  convID: 'group123',
  from: 'userA',
  timeRange: {
    startTime: new Date(2023, 0, 1).getTime(),
    endTime: new Date(2023, 1, 1).getTime()
  }
})

3. 敏感词过滤

// 集成腾讯云内容安全
export async function checkSensitiveWords(text) {
  const res = await axios.post('https://cms.tencentcloudapi.com/', {
    Action: 'TextModeration',
    Content: text,
    // 其他必要参数...
  })

  return res.data.Suggestion === 'Pass'
}

// 搜索前校验
export async function validateSearchKeyword(keyword) {
  if (await checkSensitiveWords(keyword)) {
    return keyword
  }
  throw new Error('包含敏感词汇')
}

四、高级功能扩展

1. 语音消息转文本搜索

// 集成语音识别服务
export async function transcribeAudioMessage(fileKey) {
  const res = await axios.post('https://asr.tencentcloudapi.com/', {
    Action: 'SentenceRecognition',
    ProjectId: 0,
    SubServiceType: 2,
    EngSerViceType: '16k_zh',
    SourceType: 1,
    Url: fileKey
  })

  return res.data.Result
}

// 修改搜索逻辑
async function searchAudioMessages(engine) {
  const { messages } = await executeSearch(engine)
  
  const transcriptions = await Promise.all(
    messages.filter(msg => msg.type === 'TIMAudioElem')
      .map(async msg => ({
        ...msg,
        transcription: await transcribeAudioMessage(msg.payload.fileKey)
      }))
  )
  
  return transcriptions
}

2. 搜索结果聚合

// 按发送者聚合结果
function groupBySender(messages) {
  return messages.reduce((acc, msg) => {
    if (!acc[msg.from]) acc[msg.from] = []
    acc[msg.from].push(msg)
    return acc
  }, {})
}

// 按日期聚合
function groupByDate(messages) {
  return messages.reduce((acc, msg) => {
    const dateKey = dayjs(msg.time).format('YYYY-MM-DD')
    if (!acc[dateKey]) acc[dateKey] = []
    acc[dateKey].push(msg)
    return acc
  }, {})
}

3. 搜索历史管理

// 本地存储搜索历史
export function saveSearchHistory(keyword) {
  const history = uni.getStorageSync('search_history') || []
  const newHistory = [...new Set([keyword, ...history.slice(0, 49)])]
  uni.setStorageSync('search_history', newHistory)
}

// 清除历史记录
export function clearSearchHistory() {
  uni.removeStorageSync('search_history')
}

五、常见问题排查

  1. Q: 搜索结果不完整
    A: 检查时间范围设置,确保endTime > startTime,且在有效期内(默认7天)

  2. Q: 特殊字符搜索异常
    A: 对关键词进行URL编码处理:encodeURIComponent(keyword)

  3. Q: 群聊消息搜索失败
    A: 确认群类型是否为Private(私有群),Public群需群主操作

  4. Q: 消息内容高亮失效
    A: 确保使用v-html指令渲染,并做好XSS防护:v-html="highlightedText"

六、性能优化建议

  1. 对超过1000条的会话禁用全局搜索
  2. 实现搜索结果虚拟滚动(仅渲染可视区域)
  3. 对高频关键词建立本地缓存(使用uni.setStorage
  4. 使用Web Worker处理复杂文本分析
  5. 限制最大并发搜索数为3

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2403028.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

robot_lab——rsl_rl的train.py整体逻辑

文章目录 Go2机器人训练流程详细分析概述1. 训练启动流程1.1 命令行参数解析RSL-RL相关参数组Isaac Sim应用启动参数组 1.2 RL配置1.3 Isaac Sim启动 2. 环境配置加载2.1 Hydra配置系统 3. 环境创建与初始化3.1 Gym环境创建3.2 Manager系统初始化3.2.1 ObservationManager3.2.2…

.NET 原生驾驭 AI 新基建实战系列(三):Chroma ── 轻松构建智能应用的向量数据库

在人工智能AI和机器学习ML迅猛发展的今天&#xff0c;数据的存储和检索需求发生了巨大变化。传统的数据库擅长处理结构化数据&#xff0c;但在面对高维向量数据时往往力不从心。向量数据库作为一种新兴技术&#xff0c;专为AI应用设计&#xff0c;能够高效地存储和查询高维向量…

8.RV1126-OPENCV 视频中添加LOGO

一.视频中添加 LOGO 图像大体流程 首先初始化VI,VENC模块并使能&#xff0c;然后创建两个线程&#xff1a;1.把LOGO灰度化&#xff0c;然后获取VI原始数据&#xff0c;其次把VI数据Mat化并创建一个感兴趣区域&#xff0c;最后把LOGO放感兴趣区域里并把数据发送给VENC。2.专门获…

API管理是什么?API自动化测试怎么搭建?

目录 一、API管理是什么 &#xff08;一&#xff09;API管理的定义 &#xff08;二&#xff09;API管理的重要性 二、API管理的主要内容 &#xff08;一&#xff09;API设计 1. 遵循标准规范 2. 考虑可扩展性 3. 保证接口的易用性 &#xff08;二&#xff09;API开发 …

GIC v3 v4 虚拟化架构

ARMV8-A架构中包含了对虚拟化的支持。为了与架构保持匹配&#xff0c;GICV3也对虚拟化做了支持。新增了以下特性&#xff1a; 对CPU interface的硬件虚拟化虚拟中断maintenance 中断&#xff1a;用于通知监管程序&#xff08;例如hypervisor&#xff09;一些特定的虚拟机事件 …

2025远离Deno和Fresh

原创作者&#xff1a;庄晓立&#xff08;LIIGO&#xff09; 原创时间&#xff1a;2025年6月6日 原创链接&#xff1a;https://blog.csdn.net/liigo/article/details/148479884 版权所有&#xff0c;转载请注明出处&#xff01; 相识 Deno&#xff0c;是Nodejs原开发者Ryan Da…

Flask+LayUI开发手记(七):头像的上传及突破static目录限制

看了看&#xff0c;上篇开发手记是去年8月份写的&#xff0c;到现在差2个月整一年了。停更这么长时间&#xff0c;第一个原因是中间帮朋友忙一个活&#xff0c;那个技术架构是用springboot的&#xff0c;虽然前端也用layUI&#xff0c;但和Flask-python完全不搭界&#xff0c;所…

MiniExcel模板填充Excel导出

目录 1.官方文档 2. 把要导出的数据new一个匿名对象 3.导出 4.注意事项 5.模板制作 6.结果 1.官方文档 https://gitee.com/dotnetchina/MiniExcel/#%E6%A8%A1%E6%9D%BF%E5%A1%AB%E5%85%85-excel // 1. By POCO var value new {Name "Jack",CreateDate n…

MCP协议重构AI Agent生态:万能插槽如何终结工具孤岛?

前言 在人工智能技术快速发展的2025年&#xff0c;MCP(Model Context Protocol&#xff0c;模型上下文协议)正逐渐成为AI Agent生态系统的关键基础设施。这一由Anthropic主导的开放协议&#xff0c;旨在解决AI模型与外部工具和数据源之间的连接难题&#xff0c;被业界形象地称…

阿里云事件总线 EventBridge 正式商业化,构建智能化时代的企业级云上事件枢纽

作者&#xff1a;肯梦、稚柳 产品演进历程&#xff1a;在技术浪潮中的成长之路 早在 2018 年&#xff0c;Gartner 评估报告便将事件驱动模型&#xff08;Event-Driven Model&#xff09;列为十大战略技术趋势之一&#xff0c;指出事件驱动架构&#xff08;EDA&#xff0c;Eve…

CentOS8.3+Kubernetes1.32.5+Docker28.2.2高可用集群二进制部署

一、准备工作 1.1 主机列表 HostnameHost IPDocker IPRolek8s31.vm.com192.168.26.3110.26.31.1/24master&worker、etcd、dockerk8s32.vm.com192.168.26.3210.26.32.1/24master&worker、etcd、dockerk8s33.vm.com192.168.26.3310.26.33.1/24master&worker、etcd、…

学习日记-day23-6.6

完成目标&#xff1a; 知识点&#xff1a; 1.IO流_转换流使用 ## 转换流_InputStreamReader1.字节流读取中文在编码一致的情况,也不要边读边看,因为如果字节读不准,读不全,输出的内容有可能会出现乱码 2.所以,我们学了字符流,字符流读取文本文档中的内容如果编码一致,就不会出…

Pytorch安装后 如何快速查看经典的网络模型.py文件(例如Alexnet,VGG)(已解决)

当你用conda 安装好虚拟环境后&#xff0c; 找到你的Anaconda 的安装位置。 我的在D盘下&#xff1b; 然后 从Anaconda3文件夹开始&#xff1a;一级一级的查看&#xff0c;一直到models Anaconda3\envs\openmmlab\Lib\site-packages\torchvision\models 在models下面&#x…

有人-无人(人机)交互记忆、共享心智模型与AI准确率的边际提升

有人-无人&#xff08;人机&#xff09;交互记忆、共享心智模型与AI准确率的边际提升是人工智能发展中相互关联且各有侧重的三个方面。人机交互记忆通过记录和理解用户与机器之间的交互历史&#xff0c;增强机器对用户需求的个性化响应能力&#xff0c;从而提升用户体验和协作效…

【OpenGL学习】(五)自定义着色器类

文章目录 【OpenGL学习】&#xff08;五&#xff09;自定义着色器类着色器类插值着色统一着色 【OpenGL学习】&#xff08;五&#xff09;自定义着色器类 项目结构&#xff1a; 着色器类 // shader_s.h #ifndef SHADER_H #define SHADER_H#include <glad/glad.h>#inc…

408第一季 - 数据结构 - 栈与队列的应用

括号匹配 用瞪眼法就可以知道的东西 栈在表达式求值运用 先简单看看就行&#xff0c;题目做了就理解了 AB是操作符,也是被狠狠加入后缀表达式了&#xff0c;然后后面就是*&#xff0c;只要优先级比栈顶运算符牛逼就放里面&#xff0c;很显然&#xff0c;*比牛逼 继续前进&#…

超声波清洗设备的清洗效果如何?

超声波清洗设备是一种常用于清洗各种物体的技术&#xff0c;它通过超声波振荡产生的微小气泡在液体中破裂的过程来产生高能量的冲击波&#xff0c;这些冲击波可以有效地去除表面和细微裂缝中的污垢、油脂、污染物和杂质。超声波清洗设备在多个领域得到广泛应用&#xff0c;包括…

“草台班子”的成长路径分析

一、草台班子的起点&#xff1a;用最小成本验证价值 特点&#xff1a; 团队规模小&#xff08;通常3-5人&#xff09;&#xff0c;成员背景杂&#xff08;可能是程序员产品经理运营的混搭&#xff09;&#xff1b;资源匮乏&#xff08;无资金、无技术中台、无客户积累&#x…

软件测评服务如何依据标准确保品质?涵盖哪些常见内容?

软件测评服务涉及对软件的功能和性能等多维度进行评估和检验&#xff0c;这一过程有助于确保软件的品质&#xff0c;降低故障发生率及维护费用&#xff0c;对于软件开发和维护环节具有至关重要的价值。 测评标准依据 GB/T 25000.51 - 2016是软件测评的核心依据。依照这一标准…

Python打卡第46天

浙大疏锦行 注意力 注意力机制是一种让模型学会「选择性关注重要信息」的特征提取器&#xff0c;就像人类视觉会自动忽略背景&#xff0c;聚焦于图片中的主体&#xff08;如猫、汽车&#xff09;。 从数学角度看&#xff0c;注意力机制是对输入特征进行加权求和&#xff0c;…