首页 > 解决方案 > 如何使用 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 发送数据?

标签: websocketpuppeteerpuppeteer-sharp

解决方案


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}");

更多信息可以在文档中找到。


推荐阅读