第一次写文章,记录一下分析的过程。
1. 分析:弹幕消息连接是websocket 协议的,选中WS 即可查看websocket 的连接
2. 搜索new WebSocket 关键词进行定位找到相应的js文件
onMessage 是监听服务端发过来的消息,
进入e方法
继续进入this.bindClientMessage方法
进入bindClientMessage 方法后发现 r.toObject()的数据是服务端发送过来的,payload 数据是密文格式的,继续进入this.emit 方法找到明文数据
t 就是获取的messageList, 继续进入this.runAllEvents 方法
发现s.toObject() 的数据是明文数据 ,此时我们可以此位置上方写一个websocket 的客户端,把明文数据发送到本地的websocket 服务端,这样服务端就可以源源不断地接收到弹幕消息了
植入websocket 客户端代码
代码示例:
window.dataLx = s.toObject();
!function(){
var res = window.dataLx;
if (window.flagLX) {
console.log('111')
window.ws.send(JSON.stringify(res));
}
else {
var ws = new WebSocket("ws://127.0.0.1:9000");
window.ws = ws;
window.flagLX = true;
ws.addEventListener('open', event => {
console.log('Connected to server');
ws.send(JSON.stringify({"msg":"hello!"}));
ws.send(JSON.stringify(res));
});
}
}();
python 服务端代码:
import asyncio
import websockets
async def handle_connection(websocket, path):
async for message in websocket:
print(message)
async def start_server():
async with websockets.serve(handle_connection, "127.0.0.1", 9000):
await asyncio.Future() # 防止服务器退出
if __name__ == '__main__':
asyncio.run(start_server())
开启服务端后,再打开直播,服务端就可以不断收到数据了