跳至页脚内容
.NET 帮助

Socket io .NET(对开发人员的工作原理)

通过Socket.IO库,服务器能够提供实时、双向和事件驱动的通信。 它广泛用于网络应用程序中,如聊天应用、实时更新和协作平台等任务。 尽管Socket.IO通常与JavaScript关联,它也可以在客户端与C#一起有效地使用。 有时客户端可能是一个网络浏览器。 在本文中,我们将探讨如何在C#环境中设置和使用Socket.IO客户端。 我们将浏览一些基本示例,并总结其优势和潜在用例。

建立Socket.IO连接的方法

Socket.IO连接可以通过不同的低级传输协议建立:

  • HTTP长轮询
  • Web Sockets

  • Web Transport

Socket io .NET(开发人员如何操作):图1 - 客户端-服务器通信应用程序

在Visual Studio 2022中创建控制台项目

打开Visual Studio,并在起始窗口中选择创建新项目

Socket io .NET(开发人员如何操作):图2 - 显示创建新项目窗口的截图。

要在Visual Studio 2022中创建控制台应用程序,请启动Visual Studio并从起始窗口选择"创建新项目"。 选择"控制台应用"模板,配置项目名称和位置,并确保选择.NET 6.0。

什么是Socket.IO?

Socket.IO是一个JavaScript库,能够使网页客户端与服务器进行实时通信。 它由两个部分组成:

Socket IO的部分

  • 客户端库:在浏览器中运行。
  • 服务器端库:在Node.js上运行。

安装必要的包

要在Visual Studio中使用Socket.IO进行.NET应用程序,您需要一个兼容的服务器实现。 其中一个实现是 SocketIoClientDotNet,用于.NET,允许Socket.IO客户端从C#应用程序连接到Socket.IO。

首先,安装所需的NuGet包。 您可以通过包管理器控制台或通过将引用添加到项目文件中进行此操作:

Install-Package SocketIoClientDotNet

SocketIoClientDotNet包的截图

Socket io .NET(开发人员如何操作):图3 - 使用NuGet包管理器解决方案的管理NuGet包搜索栏中搜索SocketIoClientDotNet包名,选择项目并点击安装按钮安装Socket.IO for NET。

执行此命令将Socket.IO客户端库集成到您的.NET项目中,增强您的C#应用程序与Socket.IO服务器连接,促进用户与系统之间的通信。

创建Socket.IO

在深入研究C#客户端之前,让我们使用.NET Core的控制台应用在Visual Studio中设置一个基本的Socket IO示例。 这将帮助我们测试客户端实现。

创建服务器实现

以下代码在C#中设置了一个基本的Socket.IO服务器,监听客户端连接到端口3000。当客户端发送消息时,服务器记录消息并响应回客户端,确认收到。

using System;
using System.Net.WebSockets;
using System.Text;
using System.Threading;
using System.Threading.Tasks;
using Quobject.SocketIoClientDotNet.Client;

namespace DemoApp
{
    internal class Program
    {
        static void Main(string[] args)
        {
            // Connect to the Socket.IO server
            var socket = IO.Socket("http://localhost:3000");

            // Listen for the "connect" event
            socket.On(Socket.EVENT_CONNECT, () =>
            {
                Console.WriteLine("Connected to the server!");

                // Emit a message to the server
                socket.Emit("message", "Hello from C# client!");

                // Listen for messages from the server
                socket.On("message", (data) =>
                {
                    Console.WriteLine("Message from server: " + data);
                });
            });

            // Listen for the "disconnect" event
            socket.On(Socket.EVENT_DISCONNECT, () =>
            {
                Console.WriteLine("Disconnected from the server!");
            });

            // Keep the console window open
            Console.ReadLine();
        }
    }
}
using System;
using System.Net.WebSockets;
using System.Text;
using System.Threading;
using System.Threading.Tasks;
using Quobject.SocketIoClientDotNet.Client;

namespace DemoApp
{
    internal class Program
    {
        static void Main(string[] args)
        {
            // Connect to the Socket.IO server
            var socket = IO.Socket("http://localhost:3000");

            // Listen for the "connect" event
            socket.On(Socket.EVENT_CONNECT, () =>
            {
                Console.WriteLine("Connected to the server!");

                // Emit a message to the server
                socket.Emit("message", "Hello from C# client!");

                // Listen for messages from the server
                socket.On("message", (data) =>
                {
                    Console.WriteLine("Message from server: " + data);
                });
            });

            // Listen for the "disconnect" event
            socket.On(Socket.EVENT_DISCONNECT, () =>
            {
                Console.WriteLine("Disconnected from the server!");
            });

            // Keep the console window open
            Console.ReadLine();
        }
    }
}
$vbLabelText   $csharpLabel

代码解释

在代码中,我们首先通过调用IO.Socket("http://localhost:3000")来创建Socket.IO客户端实例,该实例连接到客户端计算机上运行在端口3000的本地服务器。

连接成功后(Socket.EVENT_CONNECT),我们打印一条消息,表明我们已连接到服务器。

然后,我们使用socket.Emit("message", "Hello from C# client!")从客户端向服务器发送消息。 这条消息内容为"来自C#客户端的问候!"发送到服务器。

接下来,我们通过注册"message"事件的回调来监听来自服务器的消息,使用socket.On("message", (data) => { ...)。 })`。 当服务器发送"消息"事件时,回调函数被调用,我们将接收到的消息打印到控制台。

如果客户端与服务器的连接被断开(Socket.EVENT_DISCONNECT),我们将打印一条指示断开的消息。

最后,Console.ReadLine() 方法保持控制台窗口打开,以便程序在执行后不会立即退出。 这使我们能够看到输出,并确保程序不会过早终止。

代码的屏幕截图

HTTP长轮询

长轮询是一种在Web开发中使用的技术,它使用一个库在客户端(通常是Web浏览器)和服务器之间发送消息。

它通过在服务器上触发事件来实现实时通信,客户端可以接收这些事件,而无需持续轮询。 此方法对于需要即时更新的应用程序特别有效,例如聊天应用程序或股票行情。 该方法特别适用于需要即时更新的应用程序,例如聊天应用程序或股票行情。

WebSocket通过在单个TCP连接上建立全双工的通信通道,促进双向通信。

WebSocket通过在单个TCP连接上建立全双工的通信通道,促进双向通信。

该协议使客户端(通常为Web浏览器)和服务器之间的实时交互成为可能,促进双方异步交换消息。 ### 建立WebSocket通信

建立 WebSocket 通信

在收到握手请求后,服务器响应WebSocket握手响应,表明连接已成功建立。 通过WebSocket连接发送的消息可以是任何格式的(例如,文本或二进制),并以异步方式进行发送和接收。 作为一项前沿协议,Web Transport引入了额外的特性,以增强网络通信,超越像TCP和UDP这样的传统协议的限制。通过利用UDP和QUIC,它解决了其前身的缺点,使其更加用户友好和高效。

作为一项前沿协议,Web Transport引入了额外的特性,以增强网络通信,超越像TCP和UDP这样的传统协议的限制。通过利用UDP和QUIC,它解决了其前身的缺点,使其更加用户友好和高效。

对于用户而言,这意味着降低延迟和改进拥塞控制,最终提供更顺畅和响应迅速的网络体验。 此外,Web Transport提供了更好的安全措施,确保数据传输比TCP更加安全。在这些进步中,Web Transport减少了耗时的数据传输步骤,优化了客户端和服务器的整体性能。 以下是Web Transport在Web应用程序中的一个基本示例:

在这个示例中,我们首先使用WebSocket URL (wss://echo.websocket.org)创建一个新的WebSocket 连接到服务器。

using System;
using System.Net.WebSockets;
using System.Threading;
using System.Threading.Tasks;

namespace SocketIO.Demo
{
    class Program
    {
        static async Task Main(string[] args)
        {
            // The WebSocket URI
            string uri = "wss://echo.websocket.org";

            // Creating a new WebSocket connection
            using (ClientWebSocket webSocket = new ClientWebSocket())
            {
                await webSocket.ConnectAsync(new Uri(uri), CancellationToken.None);
                Console.WriteLine("Connected to the server");

                // Sending data over the WebSocket
                byte[] sendBuffer = new byte[] { 1, 2, 3, 4 };
                await webSocket.SendAsync(new ArraySegment<byte>(sendBuffer), WebSocketMessageType.Binary, true, CancellationToken.None);
                Console.WriteLine("Data sent to the server");

                // Receiving data from the WebSocket
                byte[] receiveBuffer = new byte[1024];
                WebSocketReceiveResult result = await webSocket.ReceiveAsync(new ArraySegment<byte>(receiveBuffer), CancellationToken.None);
                byte[] data = new byte[result.Count];
                Array.Copy(receiveBuffer, data, result.Count);
                Console.WriteLine("Received data: " + BitConverter.ToString(data));
            }
        }
    }
}
using System;
using System.Net.WebSockets;
using System.Threading;
using System.Threading.Tasks;

namespace SocketIO.Demo
{
    class Program
    {
        static async Task Main(string[] args)
        {
            // The WebSocket URI
            string uri = "wss://echo.websocket.org";

            // Creating a new WebSocket connection
            using (ClientWebSocket webSocket = new ClientWebSocket())
            {
                await webSocket.ConnectAsync(new Uri(uri), CancellationToken.None);
                Console.WriteLine("Connected to the server");

                // Sending data over the WebSocket
                byte[] sendBuffer = new byte[] { 1, 2, 3, 4 };
                await webSocket.SendAsync(new ArraySegment<byte>(sendBuffer), WebSocketMessageType.Binary, true, CancellationToken.None);
                Console.WriteLine("Data sent to the server");

                // Receiving data from the WebSocket
                byte[] receiveBuffer = new byte[1024];
                WebSocketReceiveResult result = await webSocket.ReceiveAsync(new ArraySegment<byte>(receiveBuffer), CancellationToken.None);
                byte[] data = new byte[result.Count];
                Array.Copy(receiveBuffer, data, result.Count);
                Console.WriteLine("Received data: " + BitConverter.ToString(data));
            }
        }
    }
}
$vbLabelText   $csharpLabel

然后,我们在连接上创建一个双向的流,并通过流发送一些数据([1, 2, 3, 4])。 然后,我们在连接上创建一个双向流,并通过该流发送一些数据([1, 2, 3, 4])。 最后,我们从流中读取数据并将其记录到控制台。

上述代码的输出

当您使用 WebSocket 回声服务器运行应用程序时,输出应该类似于:

Socket io .NET(开发者如何使用):图 6 - 使用 WebSocket URL 的 WebSocket 连接的控制台输出。

  • 现代替代方案:Web Transport提供了传统网络通信协议(如TCP和UDP)的现代替代方案。

  • 高效的数据传输:通过利用多路复用流和先进的特性,它提供了高效的数据传输。
  • 高性能:非常适合构建对低延迟和可靠数据传输有极高要求的高性能Web应用程序。
  • 多路复用流:支持多路复用流,同一个连接上可以同时发送和接收多条数据流。
  • 创新:随着Web开发人员继续采用Web Transport,我们可以期待在网络通信协议领域看到更多创新。
  • 改善的用户体验:采用Web Transport可以带来更快和更可靠的数据传输,从而改善网络用户体验。
  • 改进的用户体验:采用 Web 传输可以由于更快和更可靠的数据传输而改善网页上的用户体验。

IronPDF是一个多功能的.NET PDF库,专为使用C#的开发人员设计。

该功能强大的工具允许开发人员在其应用程序中轻松创建操作读取PDF文件。 使用IronPDF,开发人员可以从HTML字符串HTML文件URL生成PDF文档,使其在各种用途中显得高度灵活。 使用IronPDF,开发者可以从 HTML字符串HTML文件URLs 生成PDF文档,使其在各种用例中具有高度的灵活性。 通过NuGet包管理器简化C#项目中的PDF文件处理过程,简化了开发并提高了生产力。 Socket io .NET(开发人员如何操作):图7 - IronPDF for .NET: C# PDF库

Socket io .NET(开发者如何使用):图7 - IronPDF for .NET:C# PDF库

使用 NuGet 包管理器进行安装

在Visual Studio中,进入控制台: 在 Visual Studio 中,转到控制台:

IronPDF代码示例

Install-Package IronPdf

下面是一个使用IronPDF将二进制数据转换为PDF文件的简单示例。在Main方法中调用GeneratePDF方法并将数据作为参数传递给此前的示例中的数据:

PDF生成类代码

using System;
using System.Net.WebSockets;
using System.Threading;
using System.Threading.Tasks;

namespace SocketIO.Demo
{
    class Program
    {
        static async Task Main(string[] args)
        {
            // The WebSocket URI
            string uri = "wss://echo.websocket.org";

            // Creating a new WebSocket connection
            using (ClientWebSocket webSocket = new ClientWebSocket())
            {
                await webSocket.ConnectAsync(new Uri(uri), CancellationToken.None);
                Console.WriteLine("Connected to the server");

                // Sending data over the WebSocket
                byte[] sendBuffer = new byte[] { 1, 2, 3, 4 };
                await webSocket.SendAsync(new ArraySegment<byte>(sendBuffer), WebSocketMessageType.Binary, true, CancellationToken.None);
                Console.WriteLine("Data sent to the server");

                // Receiving data from the WebSocket
                byte[] receiveBuffer = new byte[1024];
                WebSocketReceiveResult result = await webSocket.ReceiveAsync(new ArraySegment<byte>(receiveBuffer), CancellationToken.None);
                byte[] data = new byte[result.Count];
                Array.Copy(receiveBuffer, data, result.Count);
                Console.WriteLine("Received data: " + BitConverter.ToString(data));

                // Data to generate in PDF file
                string pdfData = BitConverter.ToString(data);
                PDFGenerator.GeneratePDF(pdfData);
            }
        }
    }
}
using System;
using System.Net.WebSockets;
using System.Threading;
using System.Threading.Tasks;

namespace SocketIO.Demo
{
    class Program
    {
        static async Task Main(string[] args)
        {
            // The WebSocket URI
            string uri = "wss://echo.websocket.org";

            // Creating a new WebSocket connection
            using (ClientWebSocket webSocket = new ClientWebSocket())
            {
                await webSocket.ConnectAsync(new Uri(uri), CancellationToken.None);
                Console.WriteLine("Connected to the server");

                // Sending data over the WebSocket
                byte[] sendBuffer = new byte[] { 1, 2, 3, 4 };
                await webSocket.SendAsync(new ArraySegment<byte>(sendBuffer), WebSocketMessageType.Binary, true, CancellationToken.None);
                Console.WriteLine("Data sent to the server");

                // Receiving data from the WebSocket
                byte[] receiveBuffer = new byte[1024];
                WebSocketReceiveResult result = await webSocket.ReceiveAsync(new ArraySegment<byte>(receiveBuffer), CancellationToken.None);
                byte[] data = new byte[result.Count];
                Array.Copy(receiveBuffer, data, result.Count);
                Console.WriteLine("Received data: " + BitConverter.ToString(data));

                // Data to generate in PDF file
                string pdfData = BitConverter.ToString(data);
                PDFGenerator.GeneratePDF(pdfData);
            }
        }
    }
}
$vbLabelText   $csharpLabel

Socket io .NET(开发人员如何操作):图8 - 使用Socket.IO和IronPDF的控制台输出

using IronPdf;

namespace SocketIO.Demo
{
    public class PDFGenerator
    {
        public static void GeneratePDF(string data)
        {
            IronPdf.License.LicenseKey = "Your-Licence-Key-Here";
            Console.WriteLine("PDF Generating Started...");

            // Instantiate Renderer
            var renderer = new ChromePdfRenderer();
            Console.WriteLine("PDF Processing ....");

            var pdf = renderer.RenderHtmlAsPdf($"<h1>Received Data</h1><p>{data}</p>");
            string filePath = "Data.pdf";
            pdf.SaveAs(filePath);
            Console.WriteLine($"PDF Generation Completed. File Saved as {filePath}");
        }
    }
}
using IronPdf;

namespace SocketIO.Demo
{
    public class PDFGenerator
    {
        public static void GeneratePDF(string data)
        {
            IronPdf.License.LicenseKey = "Your-Licence-Key-Here";
            Console.WriteLine("PDF Generating Started...");

            // Instantiate Renderer
            var renderer = new ChromePdfRenderer();
            Console.WriteLine("PDF Processing ....");

            var pdf = renderer.RenderHtmlAsPdf($"<h1>Received Data</h1><p>{data}</p>");
            string filePath = "Data.pdf";
            pdf.SaveAs(filePath);
            Console.WriteLine($"PDF Generation Completed. File Saved as {filePath}");
        }
    }
}
$vbLabelText   $csharpLabel

输出

在提供的代码中,IronPDF用于从通过WebSocket连接接收到的十六进制字符串生成PDF文档。

GeneratePDF方法使用许可证密钥初始化IronPDF,并利用其ChromePdfRenderer实例将十六进制字符串作为HTML内容渲染为PDF,使用RenderHtmlAsPdf方法。 您可以在此处获取免费许可证密钥。 此PDF随后通过SaveAs方法本地保存为"Data.pdf"。 然后使用 SaveAs 方法将此PDF本地保存为"Data.pdf"。 ### 生成的PDF文件

生成的 PDF 文件

Socket io .NET(开发者如何使用):图 9 - 使用 IronPDF 生成的输出 PDF

结论

使用 Socket.IO 和 C# 介绍了与连接客户端实时交互的众多机会,超越了 JavaScript 和 Node.js 的领域。 将像 Socket.IO 和 IronPDF 这样的工具集成到您的 .NET 项目中,可以显著提升实时通信和 PDF 处理能力。 Socket.IO 可促进客户端和服务器之间的无缝实时双向通信,而 IronPDF 则为轻松创建操作PDF 文档提供了强大的功能。

常见问题解答

如何在C#环境中设置Socket.IO客户端?

要在C#环境中设置Socket.IO客户端,可以使用SocketIoClientDotNet包。这使您的C#应用程序能够与Socket.IO服务器通信,促进实时的双向通信。

在Web应用程序中使用Socket.IO有哪些优势?

Socket.IO提供实时、双向和事件驱动的通信,非常适合需要实时更新的Web应用程序,如聊天应用、协作平台和在线游戏。

我可以在Visual Studio 2022中使用Socket.IO吗?

是的,您可以通过创建控制台项目并安装诸如SocketIoClientDotNet之类的必要软件包,在Visual Studio 2022中使用Socket.IO,以便在您的C#应用程序中实现实时通信。

IronPDF如何增强使用Socket.IO的实时应用程序?

IronPDF可以通过允许开发人员从实时的WebSocket数据生成和操作PDF来增强实时应用程序。这对于从动态数据流创建结构化文档非常有用。

连接C#客户端到Socket.IO服务器的过程是什么?

要连接C#客户端到Socket.IO服务器,您需要使用SocketIoClientDotNet包。这包括设置客户端监听和发送事件,使其能够与服务器进行实时通信。

HTTP长轮询在Socket.IO中如何工作?

HTTP长轮询是Socket.IO使用的一种方法,通过保持请求打开直到服务器响应,以便在新数据可用时立即进行更新,维持持久连接。

WebSocket在Socket.IO通信中扮演什么角色?

WebSocket在Socket.IO通信中扮演关键角色,通过单一的TCP连接实现全双工通信,促进客户端与服务器之间的高效实时数据交换。

如何安装SocketIoClientDotNet包?

您可以使用Visual Studio中的NuGet包管理器安装SocketIoClientDotNet包。打开包管理器控制台并执行命令:Install-Package SocketIoClientDotNet

将IronPDF与Socket.IO集成的用例是什么?

将IronPDF与Socket.IO集成对于需要从动态数据生成PDF的实时应用程序非常有用,例如报告工具、实时数据分析和自动化文档生成系统。

使用Web Transport在Socket.IO中有什么好处?

Web Transport在传统的TCP和UDP上提供了改进的延迟和拥堵控制,支持多路复用流和增强的安全性,适合现代实时通信需求。

Jacob Mellor,Team Iron 的首席技术官
首席技术官

Jacob Mellor 是 Iron Software 的首席技术官,是 C# PDF 技术的先锋工程师。作为 Iron Software 核心代码库的原始开发者,自公司成立以来,他就塑造了公司的产品架构,并与首席执行官 Cameron Rimington 一起将其转变成一家公司,拥有50多人,服务于 NASA、特斯拉和全球政府机构。

Jacob 拥有曼彻斯特大学 (1998-2001) 的一级荣誉土木工程学士学位。1999 年在伦敦创办了自己的第一家软件公司,并于 2005 年创建了他的第一个 .NET 组件后,他专注于解决微软生态系统中的复杂问题。

他的旗舰 IronPDF 和 Iron Suite .NET 库在全球已获得超过 3000 万次的 NuGet 安装,其基础代码继续为全球使用的开发者工具提供支持。拥有 25 年商业经验和 41 年编程经验的 Jacob 仍专注于推动企业级 C#、Java 和 Python PDF 技术的创新,同时指导下一代技术领导者。