用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       

相关内容

热门资讯

五分钟规律!德州ai机器人软件... 五分钟规律!德州ai机器人软件开发(透视辅助)外挂透明挂辅助挂(2023已更新)(哔哩哔哩);1、德...
十分钟分享!微扑克俱乐部24小... 十分钟分享!微扑克俱乐部24小时(透视)原来真的有挂(有挂脚本)-小红书;1、微扑克俱乐部24小时a...
8分钟分析!德扑之星禁止模拟器... 8分钟分析!德扑之星禁止模拟器(辅助)外挂透明挂辅助工具(2024已更新)(哔哩哔哩);1、起透看视...
3分钟曝光!微扑克专用辅助程序... 3分钟曝光!微扑克专用辅助程序(辅助挂)外挂透明挂辅助挂(2024已更新)(哔哩哔哩);1、进入到微...
9分钟安装!wpk辅助神器(透... 9分钟安装!wpk辅助神器(透明挂)好像真的有挂(有挂教学)-百度知乎1、wpk辅助神器系统规律教程...
四分钟内幕!德扑之星怎么查数据... 四分钟内幕!德扑之星怎么查数据(透明挂)外挂透明挂辅助挂(2020已更新)(哔哩哔哩)1、进入到德扑...
3分钟细节!扑克时间假不假(透... 3分钟细节!扑克时间假不假(透明挂)果然真的有挂(有挂脚本)-哔哩哔哩扑克时间假不假辅助器中分为三种...
十分钟介绍!云扑克辅助器(透视... 十分钟介绍!云扑克辅助器(透视)外挂透明挂辅助插件(2020已更新)(哔哩哔哩);1、下载好云扑克辅...
5分钟普及!wepoke ai... 5分钟普及!wepoke ai(软件透明挂)一直真的有挂(有挂脚本)-微博客户端1、用户打开应用后不...
5分钟教程!Aapoker a... 5分钟教程!Aapoker app(辅助透视)外挂透明挂辅助工具(2024已更新)(哔哩哔哩);在进...