用http方式实现websocket,如chatGPT时时打字效果,原生方式:fetch+sse+post
创始人
2024-11-10 03:40:44
0

用http方式实现websocket,如chatGPT时时打字效果,原生方式:fetch+sse+post

fetch实现stream、原生fetch+sse+post

fetch 本身不直接支持流式输出,但你可以使用 ReadableStream 和 TextDecoder 等 Web Streams API 来实现类似的效果。

后端:比如python, php, java 等等都行...   核心是前端,在下面会有完整展示

from fastapi import FastAPI, Response from fastapi.responses import StreamingResponse import json import time from fastapi.middleware.cors import CORSMiddleware #解决跨域 from fastapi import FastAPI, File, UploadFile,Form,Request # from sse_starlette.sse import EventSourceResponse   app = FastAPI()   # 假设这是你想按事件流形式发送的JSON数据 data = {     "messages": [         {"text": "Hello, 1!", "timestamp": "2021-01-01T12:00:00"},         {"text": "Hello, 2!", "timestamp": "2021-01-02T12:00:01"},         {"text": "Hello, 3!", "timestamp": "2021-01-02T12:00:02"},     ] }  def generate_json_stream(data):     # 分割JSON数据,并逐个发送     for message in data["messages"]:         json_str = json.dumps(message)         yield json_str.encode("utf-8") #发送当前值给前端         time.sleep(1)  # 模拟延时   # 配置 CORSMiddleware 跨域 app.add_middleware(     CORSMiddleware,     allow_origins=["*"],        # 允许访问的源     allow_credentials=True,     # 支持 cookie     allow_methods=["*"],        # 允许使用的请求方法     allow_headers=["*"]         # 允许携带的 Headers )  @app.post("/stream-json") async def stream_json( request: Request,foo: str = Form(default='') ):            # 获取json         json_data = await request.json()     getHeader = request.headers     print('----1-----',json_data,getHeader)      # return EventSourceResponse(generate_json_stream(data), media_type="text/event-stream")     return StreamingResponse(generate_json_stream(data), media_type="text/event-stream")    if __name__ == "__main__":     import uvicorn     uvicorn.run(app, host="0.0.0.0", port=16887) 

核心是前端:

     原生fetch+sse+post       

相关内容

热门资讯

现有说明如下!wpk俱乐部是真... 现有说明如下!wpk俱乐部是真的吗,we-poker辅助(透视)手段教程(都是存在有挂)1、玩家可以...
无独有偶!约局吧德州有挂吗,w... 无独有偶!约局吧德州有挂吗,wepoker私人局外卦(透视)攻略教程(一直是真的挂)1、下载好约局吧...
长期以来!德普软件,拱趴大菠萝... 长期以来!德普软件,拱趴大菠萝挂哪里(透视)资料教程(一贯真的是有挂)1、完成拱趴大菠萝挂哪里辅助器...
无独有偶!aapoker辅助软... 无独有偶!aapoker辅助软件合法吗,aapoker万能辅助器(透视)模块教程(其实真的是有挂)一...
随着!智星德州可以透视吗,we... 随着!智星德州可以透视吗,wepoker免费脚本弱密码(透视)指南教程(好像真的有挂)1、每一步都需...
更值得关注的是!epoker免... 更值得关注的是!epoker免费透视脚本,悦扑克脚本(透视)手筋教程(切实是有挂)1、进入游戏-大厅...
截至目前!wepokerplu... 截至目前!wepokerplus透视脚本免费,hhpoker辅助挂(透视)讲义教程(好像真的有挂)1...
现有说明如下!wepoker脚... 现有说明如下!wepoker脚本,wepoker辅助软件视频(透视)总结教程(果然存在有挂)1、we...
刚刚!hhpoker可以控制牌... 刚刚!hhpoker可以控制牌吗,wepoker轻量版透视方法(透视)教材教程(其实是真的挂)暗藏猫...
无独有偶!hhpoker是真的... 无独有偶!hhpoker是真的还是假的,wpk德州局怎么透视(透视)阶段教程(好像存在有挂)1.hh...