用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       

相关内容

热门资讯

黑科技实锤(wepoke透明黑... 黑科技实锤(wepoke透明黑科技)wepoke辅助多久会检测到(wepOke)起初存在有挂(有挂秘...
黑科技了解!aapoker辅助... 黑科技了解!aapoker辅助(微扑克真的有挂)切实有挂(有挂黑科技ai)-哔哩哔哩1、金币登录送、...
黑科技计算(wpk最新黑科技)... 黑科技计算(wpk最新黑科技)wpk ai辅助安全吗(wpK)真是真的有挂(有挂详细)-哔哩哔哩1、...
黑科技安装(wepoke真的有... 黑科技安装(wepoke真的有挂)wepoke透明挂使用教程(wopoker)原本有挂(揭秘有挂)-...
黑科技ai(wpk最新黑科技)... 黑科技ai(wpk最新黑科技)wpk透明挂(wpK)竟然有挂(证实有挂)-哔哩哔哩1、wpk最新黑科...
黑科技计算!德州之星辅助(德州... 黑科技计算!德州之星辅助(德州ai软件购买)竟然存在有挂(有挂ai代打)-哔哩哔哩;1、下载好德州之...
黑科技免费(wpk最新黑科技)... 黑科技免费(wpk最新黑科技)wpk辅助软件(WPK)竟然有挂(有挂方式)-哔哩哔哩1、每一步都需要...
黑科技新版(wepoke黑科技... 自定义系统规律,只需要输入自己想要的开挂功能,一键便可以生成出微扑克专用辅助器,不管你是想分享给你好...
黑科技好友!德扑之星系统发牌机... 黑科技好友!德扑之星系统发牌机制(aapoker真的有猫腻)竟然真的有挂(有挂软件透明挂)-哔哩哔哩...
黑科技存在(wpk最新黑科技)... 黑科技存在(wpk最新黑科技)wpkai辅助(wpK)好像真的有挂(有挂详细)-哔哩哔哩1、构建自己...