创新实训(十四) 项目开发——用户终止对话功能bug修复

bug分析

创新实训(十三) 项目开发------实现用户终止对话功能

上面的实现在后面的测试中发现有问题,当前的问题被终止后,提问下一个问题,后端已经显示了回答,前端也可以在network界面看到流式的回答,但是UI界面就是没有输出。

重新回顾上述实现,发现mixchat接口在调用stopchat接口后,仍然收到后端的sse消息,导致上一个回答还未终止,下一个回答的message已经来到,而mixchat从未abort,进一步导致了接收到的message混乱。

根本原因是**:每一次用户的query其实都是使用的最初建立的sse连接**。

修改如下

首先对变量controller和siginal进行修改:

js 复制代码
let controller = ref(null);
controller.value = new AbortController();
const signal = ref(controller.value.signal);

使用ref可以动态的监听变化。

在onsend方法中,对于点击停止的按钮处理,在接口返回ok后,新建一个controller.value。

js 复制代码
//直接断掉上一次的sse连接
controller.value= new AbortController();
signal.value =controller.value.signal;

同时增加判断:

  • 如果用户选择点击停止,进入changewait方法
  • 否则就视为开启新的对话,将isUserAbort.value设为false
js 复制代码
if(button.value.type==='info'){

    button.value.status=true;
    changeWait();
    
    return ;
  }

  //如果用户再次点击发送,再在用户中断设为false
  else  isUserAbort.value===false;

终止的关键还是在controller.value.abort();

复制代码
    controller.value.abort(); //连接没有被完全断开欸
    signal.value=controller.value.signal;
    console.log(signal.value);

实现效果如下

  • 第一种情况:

    查看网络:调用stop后mix-chat直接被中断
  • 第二种情况:

    响应在只有docs时被终止:

  • 第三种情况

    mix-chat已经返回了部分回答后被终止

相关推荐
一条咸鱼_SaltyFish11 小时前
[Day10] contract-management初期开发避坑指南:合同模块 DDD 架构规划的教训与调整
开发语言·经验分享·微服务·架构·bug·开源软件·ai编程
雒珣18 小时前
qt界面和图片疯狂变大的bug问题
开发语言·qt·bug
天才测试猿18 小时前
软件测试之bug分析定位技巧
软件测试·python·selenium·测试工具·职场和发展·测试用例·bug
zhz52141 天前
后端代码规范文档示例
重构·bug·代码规范·结对编程
luming-022 天前
java报错解决:sun.net.utils不存
java·经验分享·bug·.net·intellij-idea
星月心城2 天前
Element Plus 2.7.5 的 datetimerange 存在 is-disabled 误判 Bug(头部年份 / 月份被错误禁用)
bug
C语言不精2 天前
解决ESP出现MD5报错或验证芯片bug
嵌入式硬件·bug·esp32
萧曵 丶3 天前
Java 常用运行参数配置及实际业务详解
java·bug·优化·问题排查·生产问题
熊猫钓鱼>_>3 天前
Makefile应用场景实践日志:构建高效C/C++项目工作流
c语言·c++·bug·mfc·makefile·编译·kmp
野生技术架构师3 天前
喜提一个bug,聊聊@NotEmpty和@NotBlank
java·算法·bug