解决科大讯飞 websockets api 中的持续连接问题
使用科大讯飞的实时语音流式转写 api 时,遇到连接断开错误。这是因为在使用 websockets 协议发送音频数据时,需要遵守特定的数据包格式。具体而言,每个音频片段必须具有 3 种数据包:
- 头部包(0)表示开始传输
- 数据包(1)包含音频数据
- 尾部包(2)表示结束传输
在代码中,应通过将音频数据分块为这 3 种数据包来解决此问题。可以通过在发送数据之前将音频数据格式化为 json 来实现这一点,如下所示:
import json cc = xunfei.read_audio() print("数据:" + json.dumps(cc)) # 分割音频数据包 header = {"code": 0} # 头部包 data = {"code": 1, "data": cc} # 数据包 trailer = {"code": 2} # 尾部包 await websocket.send(str(json.dumps(header))) await websocket.send(str(json.dumps(data))) await websocket.send(str(json.dumps(trailer)))
通过实施此修改,websockets 连接将保持活动,并且能够成功接收和发送数据。