websocket - 如何使用 Puppeteer 向 WebSocket 发送数据
问题描述
我使用 puppeteer-sharp 转储通过 websockets 按页面接收和发送的数据。在 C# 中转储数据的代码:
async Task Dump()
{
var client = await _browser.Page.Target.CreateCDPSessionAsync();
await client.SendAsync("Network.enable");
client.MessageReceived += OnChromeDevProtocolMessage;
}
void OnChromeDevProtocolMessage(object sender, MessageEventArgs eventArgs)
{
if (eventArgs.MessageID == "Network.webSocketCreated")
{
Logger.Trace($"Network.webSocketCreated: {eventArgs.MessageData}");
}
else if (eventArgs.MessageID == "Network.webSocketFrameSent")
{
Logger.Trace($"Network.webSocketFrameSent: {eventArgs.MessageData}");
}
else if (eventArgs.MessageID == "Network.webSocketFrameReceived")
{
var cdpMessage = JsonConvert.DeserializeObject<CdpMessage>(eventArgs.MessageData.ToString());
ProcessMessage(cdpMessage);
}
}
有没有办法使用 puppeteer 或直接使用 Chrome 开发协议消息将数据发送到 websocket?
编辑: 或者是否有可能以某种方式获得 WebSocket 实例(或句柄)以在 JavaScript 代码中使用它来使用 EvaluateFunctionAsync 发送数据?
解决方案
QueryObjects可以在命令行 API 中使用,也可以在 Puppeteer 中使用以查找实例。之后,您只需使用 EvaluateFunction 对对象执行发送方法。在 PuppeteerSharp 中,它看起来像这样:
//CODE SNIPPET
var prototype = await page.EvaluateExpressionHandleAsync("WebSocket.prototype");
var socketInstances = await page.QueryObjectsAsync(prototype);
await page.EvaluateFunctionAsync("(instances) => {let instance = instances[0]; instance.send('Hello')}, new[] {socketInstances}");
更多信息可以在文档中找到。