【慧游鲁博】【12】小程序端 · 智能导览对接后端文物图片识别功能

文章目录

本次更新将前端 chooseImage方法与后端的文物图片识别接口对接,进一步完善了小程序端智能导览模块的多模态交互功能。

chooseImage完整的处理流程

  1. 用户选择/拍摄图片
  2. 图片上传到服务器
  3. 前端调用/artifacts/match接口
  4. 后端进行文物识别和AI处理
  5. 前端接收响应:
    • 成功:清理文本、提取推荐问题、显示结果
    • 失败:显示错误提示
  6. 更新聊天界面

调用后端接口并获取响应

js 复制代码
const result = await post('/artifacts/match', {
  imageUrl: urls[0], // 使用刚上传的图片URL
  mode: this.selectedMode || 'normal' // 携带用户选择的模式
});
  • 使用封装的post方法发送POST请求到/artifacts/match接口
  • 传递两个关键参数:
    • imageUrl: 上传到服务器的图片URL
    • mode: 用户选择的交互模式(从本地存储获取,默认为'normal')

处理响应数据

js 复制代码
// 添加AI返回的结果到消息列表
const rawResponse = result; // 直接使用AI返回的自然语言文本
const cleanResponse = this.cleanAIResponse(rawResponse);
const suggestions = this.extractSuggestions(cleanResponse);
  • rawResponse: 直接接收后端返回的原始响应数据
  • cleanAIResponse(rawResponse): 调用清理方法处理原始响应:
    • 移除AI返回内容中的特殊标记(如<think>标签)
    • 清理多余的符号(如#*等)
    • 规范化换行和空格
  • extractSuggestions(cleanResponse): 从清理后的文本中提取推荐问题:
    • 查找包含"您还可以问:"或"相关问题:"的行
    • 提取冒号后面的问题列表
    • 分割问题并去除空格

构建并添加AI回复消息

js 复制代码
this.messages.push({
  role: 'assistant',
  type: 'text',
  content: cleanResponse,
  avatar: '/static/images/ai-avatar.png',
  quickReplies: suggestions,
});
  • 构建一个新的消息对象:
    • role: 'assistant': 标识为AI回复
    • type: 'text': 消息类型为文本
    • content: 使用清理后的响应文本
    • avatar: 设置AI头像
    • quickReplies: 添加提取的推荐问题(可能为null)
  • 将消息添加到messages数组中,触发界面更新

错误处理机制

js 复制代码
} catch (error) {
  uni.hideLoading();
  let errorMessage = '文物识别失败';
  if (error.message) {
    errorMessage = error.message;
  } else if (error.code === 401) {
    errorMessage = '登录已过期,请重新登录';
  }
  uni.showToast({
    title: errorMessage,
    icon: 'none'
  });
}
  • 捕获可能发生的错误:
    • 网络错误
    • 服务器错误
    • 授权错误(401)
  • 根据错误类型设置不同的错误提示:
    • 优先使用错误对象中的message
    • 特殊处理401未授权错误
    • 默认显示"文物识别失败"
  • 使用uni.showToast显示错误提示

隐藏加载状态

js 复制代码
uni.hideLoading();
  • 无论成功还是失败,最终都会调用uni.hideLoading()隐藏加载提示

与后端接口的对应关系

后端/artifacts/match接口返回的数据结构:

  1. 成功响应
js 复制代码
{
  "success": true,
  "data": "识别结果: 贴金彩绘菩萨像\n\n文物描述: 唐代贴金彩绘...\n\n匹配度: 92.50%"
}
  • 前端直接使用data中的字符串作为rawResponse
  1. 错误响应
js 复制代码
{
  "success": false,
  "code": 401,
  "message": "未授权访问"
}
相关推荐
东东51610 小时前
xxx食堂移动预约点餐系统 (springboot+微信小程序)
spring boot·微信小程序·小程序·毕业设计·个人开发·毕设
CHU72903511 小时前
一番赏盲盒抽卡机小程序:解锁惊喜体验与社交乐趣的多元功能设计
前端·小程序·php
码界奇点11 小时前
基于Spring Boot和Vue3的无头内容管理系统设计与实现
java·spring boot·后端·vue·毕业设计·源代码管理
Rysxt_12 小时前
UniApp五大UI框架与uni-ui核心区别对比
uni-app·uni-ui
技术与健康12 小时前
什么是ADSE?逻辑驱动的软件工程新范式
软件工程
2501_9159184113 小时前
HTTPS 代理失效,启用双向认证(mTLS)的 iOS 应用网络怎么抓包调试
android·网络·ios·小程序·https·uni-app·iphone
数字游民952714 小时前
半年时间大概上了70个web站和小程序,累计提示词超过20w
人工智能·ai·小程序·vibecoding·数字游民9527
说私域14 小时前
微商企业未来迭代的核心方向与多元探索——以链动2+1模式AI智能名片商城小程序为核心支撑
大数据·人工智能·小程序·流量运营·私域运营
东东51614 小时前
基于Web的智慧城市实验室系统设计与实现vue + ssm
java·前端·人工智能·后端·vue·毕业设计·智慧城市
雾江流14 小时前
HDx播放器1.0.184 | 支持多种格式和4K/8K高清视频播放,内置推特~脸书下载器
音视频·软件工程