ChatGPT垂直行业私有数据知识库功能-咨询接口采用流式响应输出-JS和Golang ...

打印 上一主题 下一主题

主题 935|帖子 935|积分 2805

近期开发私有数据知识库功能,想要实现和ChatGPT聊天效果类似的逐字流式输出展示效果。
GPT3.5本身就有流式聊天补全接口,后端Golang对接后,也需要能流式输出。下面就介绍下前端JS后端Golang来实现这种输出效果
 
大部分介绍是使用EventStream来实现,我现在不使用EventStream也来实现同样的效果
在服务器端需要关闭输出缓冲,使得每次写入的数据能够立即发送给客户端。可以通过调用http.ResponseWriter对象的Flush方法实现。
在客户端需要使用XHR对象或WebSocket对象实现长连接,从而能够接收来自服务器的多次响应。
 
  1.     router := gin.Default()
  2.     router.GET("/", func(c *gin.Context) {
  3.         c.Header("Content-Type", "text/html;charset=utf-8")
  4.         // 关闭输出缓冲,使得每次写入的数据能够立即发送给客户端
  5.         f, ok := c.Writer.(http.Flusher)
  6.         if !ok {
  7.             c.AbortWithStatus(http.StatusInternalServerError)
  8.             return
  9.         }
  10.         // 向客户端输出数据
  11.         html := []rune(`Go-Knowledge AI,自建私有数据知识库 · 与知识库AI聊天`)
  12.         for _, str := range html {
  13.             fmt.Fprintf(c.Writer, string(str))
  14.             f.Flush()
  15.             time.Sleep(100 * time.Millisecond)
  16.         }
  17.     })
复制代码
这样我们直接访问 / ,就可以看到文字是逐字流式输出响应的
前端JS需要使用下面这种读取方式
  1. var xhr = new XMLHttpRequest();
  2. xhr.open("GET", "/");
  3. xhr.setRequestHeader("Content-Type", "text/plain");
  4. xhr.onprogress = function(event) {
  5.     console.log(event.currentTarget.responseText);
  6. };
  7. xhr.send();
复制代码

 
  开源地址:唯一客服(开源学习版)   官网地址:唯一客服官网
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

民工心事

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表