当前位置: 首页 > article >正文

uni-app流式接受消息/文件

uni-app流式接受消息/文件

问题描述

今天利用fastgpt搭建了一个局域网进行访问Ai助理,在前端通过api接口进行请求,用于接收后端的发送的流式消息,那么前端可以进行流式的获取到这个消息,也可以进行直接进行在请求发送完成以后,再进行渲染这个数据,后者显然不符合我们的需求的。今天再进行完成的时候,但是进行今天进行请求的时候,每次都是通过请求完成获取到所有的消息以后再进行渲染的。

问题解决

本来的说法是通过流式使用websocket进行接受这个数据也可以进行实现流式的消息,但是后端需要的请求的方式是POST请求,并不是WS请求,所以只能通过基本请求的方式进行完成接受的流式的数据,在普通的js或者vue项目是可以通过fetch来进行发送请求,来进行完成这个需求的,但是在uniapp中却并不支持进行使用fetch进行完成,所以这里记录一下在uniapp中如何的进行接受流数据.

  • 流式数据请求进行异步封装

    const StreamRequest = (content) => {
        return new Promise((resolve, reject) => {
            const response = uni.request({
                url: 'https://www.', // 请求地址
                method: "POST", // 你的请求方法
    			dataType: "json", // 请求的数据类型
                data: content, // 请求体
                header: {
                    'Authorization': `Bearer `,
                },
                responseType: "text",
                enableChunked: true, // 开启流传输
                success: (res) => {
                    resolve(res)
                }, // 请求成功回调
                fail: (err) => {
                    reject(err)
                } // 请求失败回调
            })
    
            // 返回请求的响应
            resolve(response)
        })
    }
    
  • 使用流失请求,一下以消息流作为的使用的式例

    const fetchStreamedResponse = async (message)=>{
    		const content={
    					"chatId": "111", 
    					"stream": true,
    					"detail": false,
    					'messages': [{
    						'role': 'user', // 用户角色,可以是user,assistant,system,function等,具体可以参考openai文档。
    						'content': `${message}`, // 用户输入的内容,可以是文本,也可以是json格式。
    					}]
    				}
          // 假设已经完成了封装,并进行了导入  
    		const resp= await StreamRequest(content)
    		console.log(resp);
    		// 返回请求头信息
    		resp.onHeadersReceived((e)=>{
    			console.log(e);
    		})
    		
    		// 成功回调 返回流传输信息 返回arrayBuffer
    		resp.onChunkReceived((e)=>{e
    			// 进行处理二进制编码
    			const decoder = new TextDecoder('utf-8'); // 创建一个utf-8解码器,用于解码二进制数据为文本。
                const txt = decoder.decode(e.data); // 解码二进制数据为文本。
    			const a=parseStream(txt)
                console.log(a); // 打印解码后的文本数据。
    		})
    	}
    

总结

前端进行通过API接口进行请求流式数据,因为在uniapp中是无法通过fetch进行实时的响应的,所以在uniapp中通过对于请求进行拿到他们的hook进行完成了流式数据的接受和实时的渲染.


http://www.kler.cn/news/294077.html

相关文章:

  • 【Java 学习】:抽象类接口
  • 未来出行:高效智能的汽车充电桩
  • CUB-200-2011数据集及该格式自己数据集制作
  • 好用的AI编程助手MarsCode[豆包]
  • 分类预测|基于CNN-LSTM-Attention卷积-长短时记忆-注意力数据分类Matlab程序 直接运行程序或替换数据集运行程序
  • 基于IMX6ULL的Cortex-A中断原理讲解,以及编写其中断向量表
  • 算法图解(8~10贪心,动态规划,K最近邻算法)
  • 代码随想录训练营day36|1049.最后一块石头的重量II,494.目标和,474.一和零
  • WEB服务与虚拟主机/IIS中间件部署
  • 【kafka】在Linux系统中部署配置Kafka的详细用法教程分享
  • Leetcode面试经典150题-210.课程表II
  • 如何让linux程序在后台执行
  • CSP-J 之C++常用英文缩写
  • 【亲测有效】nginx负载均衡指定ip端口转发,做自动切换
  • 用Python实现时间序列模型实战——Day 13: 自回归条件异方差模型 (ARCH/GARCH)
  • 《深度学习》OpenCV轮廓检测 轮廓近似 解析及实现
  • Linux date命令 日期格式化与计算
  • VScode 的下载安装及常见插件 + Git的下载和安装
  • 2024年四川省安全员A证证考试题库及四川省安全员A证试题解析
  • 数据结构(1)数据结构基础(单向链表)
  • 双雄并肩:Tesla P40 GTX 1650 AI工作站搭建指南
  • redis之缓存淘汰策略
  • Keysight U8031A DC power supply
  • MySQL表操作及约束
  • WSL 在 Windows 上删除已经安装的 Ubuntu | WSL 再次重装 Ubuntu | cv2.imshow() 弹窗支持
  • Java面试题-JavaEE框架中间件(二)
  • 基于Linux单片机的中心网关设计:实时监控传感器数据的触控屏可视化详细流程
  • Python的math库——常用数学函数全解析
  • 【软件测试】设计测试用例
  • 哈希算法是什么?