0

0

C#怎么使用WebSockets C# WebSocket服务端与客户端实现

幻夢星雲

幻夢星雲

发布时间:2026-01-04 11:19:23

|

734人浏览过

|

来源于php中文网

原创

推荐使用.NET内置System.Net.WebSockets或Microsoft.AspNetCore.WebSockets;ASP.NET Core服务端需启用AddWebSockets()和UseWebSockets(),客户端用ClientWebSocket连接,注意状态检查、异常处理与连接生命周期管理。

c#怎么使用websockets c# websocket服务端与客户端实现

在 C# 中实现 WebSocket 服务端和客户端,推荐使用 .NET 内置的 System.Net.WebSockets(适用于 .NET Core 2.1+ / .NET 5+)或更高层封装如 Microsoft.AspNetCore.WebSockets(ASP.NET Core 环境)。下面分服务端与客户端两部分,给出简洁、可直接运行的核心代码和关键说明。

ASP.NET Core 中搭建 WebSocket 服务端

这是最常用、生产就绪的方式,基于中间件托管 WebSocket 连接。

  • Startup.cs(.NET 5+ 改为 Program.cs)中启用 WebSocket:
// .NET 6+ Program.cs 示例
var builder = WebApplication.CreateBuilder(args);
builder.Services.AddWebSockets(); // 启用 WebSocket 支持

var app = builder.Build(); app.UseWebSockets(); // 必须在 UseRouting() 之后、UseEndpoints() 之前

  • 添加 WebSocket 处理中间件(例如映射到 /ws):
app.Map("/ws", async context =>
{
    if (context.WebSockets.IsWebSocketRequest)
    {
        using var webSocket = await context.WebSockets.AcceptWebSocketAsync();
        await EchoWebSocketAsync(webSocket); // 简单回声逻辑
    }
    else
    {
        context.Response.StatusCode = 400;
    }
});

// 回声处理方法(接收并原样发回) static async Task EchoWebSocketAsync(WebSocket webSocket) { var buffer = new byte[1024]; while (webSocket.State == WebSocketState.Open) { var result = await webSocket.ReceiveAsync(new ArraySegment(buffer), CancellationToken.None); if (result.MessageType == WebSocketMessageType.Text) { var message = Encoding.UTF8.GetString(buffer, 0, result.Count); Console.WriteLine($"收到: {message}"); await webSocket.SendAsync( new ArraySegment(Encoding.UTF8.GetBytes($"Echo: {message}")), WebSocketMessageType.Text, true, CancellationToken.None); } else if (result.MessageType == WebSocketMessageType.Close) { await webSocket.CloseAsync(WebSocketCloseStatus.NormalClosure, "", CancellationToken.None); break; } } }

  • 注意:需手动管理连接生命周期、并发读写(避免多个 ReceiveAsync 并发)、异常捕获和资源释放;建议配合 WebSocketManager 或 SignalR 管理多连接。

纯控制台程序实现 WebSocket 服务端(System.Net.WebSockets)

适合轻量测试或嵌入式场景,不依赖 ASP.NET Core。

mallcloud商城
mallcloud商城

mallcloud商城基于SpringBoot2.x、SpringCloud和SpringCloudAlibaba并采用前后端分离vue的企业级微服务敏捷开发系统架构。并引入组件化的思想实现高内聚低耦合,项目代码简洁注释丰富上手容易,适合学习和企业中使用。真正实现了基于RBAC、jwt和oauth2的无状态统一权限认证的解决方案,面向互联网设计同时适合B端和C端用户,支持CI/CD多环境部署,并提

下载
  • 使用 HttpListener + AcceptWebSocketAsync(仅 Windows,.NET Core 3.1+ 跨平台支持有限):
  • 更推荐方案:用 Kestrel 自托管 或第三方库如 SuperSocketWebSocketSharp(已归档但稳定)。
  • 简单示例(需 NuGet 安装 WebSocketSharp):
var wssv = new WebSocketServer("127.0.0.1:8080");
wssv.AddWebSocketService("/echo");
wssv.Start();
Console.ReadLine();
wssv.Stop();

// 自定义 Handler public class EchoHandler : WebSocketBehavior { protected override void OnMessage(MessageEventArgs e) { Send($"Echo: {e.Data}"); } }

  • ⚠️ 注意:WebSocketSharp 不支持 .NET 5+ 的默认 TLS 配置,若需 HTTPS,建议改用 Microsoft.AspNetCore.WebSocketsYarp 反向代理。

C# 客户端连接 WebSocket

使用 System.Net.WebSockets.ClientWebSocket(跨平台、内置、推荐)。

using var client = new ClientWebSocket();
await client.ConnectAsync(new Uri("ws://localhost:5000/ws"), CancellationToken.None);

// 发送文本消息 var msg = Encoding.UTF8.GetBytes("Hello Server"); await client.SendAsync( new ArraySegment(msg), WebSocketMessageType.Text, true, CancellationToken.None);

// 接收响应 var recvBuf = new byte[1024]; var recvResult = await client.ReceiveAsync( new ArraySegment(recvBuf), CancellationToken.None); string response = Encoding.UTF8.GetString(recvBuf, 0, recvResult.Count); Console.WriteLine(response);

  • 务必检查 client.State == WebSocketState.Open 再发送;
  • 接收需循环调用(WebSocket 是全双工流,不是一次请求响应);
  • 建议封装成带重连、心跳、异步队列的客户端类;
  • 如需浏览器兼容性调试,可用 Chrome 控制台 new WebSocket("ws://...") 快速验证服务端是否正常。

常见问题与建议

  • 跨域问题:ASP.NET Core 默认允许跨域请求,但 WebSocket 协议本身不走 CORS 检查;实际由 HTTP 握手阶段的 Origin 头决定,可在中间件中校验并拒绝非法来源;
  • 长连接保活:服务端定期发 Ping,客户端响应 PongClientWebSocket 自动处理 Pong,但需设置 KeepAliveInterval
  • 消息分帧与大数据:WebSocket 支持分片(result.EndOfMessage == false),接收时需缓冲拼接;
  • 替代方案:高并发、广播、身份认证等复杂需求,直接上 SignalR(自动降级、Hub 模型、集成本地/Redis 背板),它底层就基于 WebSocket。

基本上就这些。核心是分清场景:Web 应用选 ASP.NET Core WebSocket 中间件;桌面/后台服务可选 ClientWebSocket + 自建服务端或 SignalR;快速原型可用 WebSocketSharp(注意平台限制)。不复杂但容易忽略错误处理和连接状态管理。

相关专题

更多
什么是中间件
什么是中间件

中间件是一种软件组件,充当不兼容组件之间的桥梁,提供额外服务,例如集成异构系统、提供常用服务、提高应用程序性能,以及简化应用程序开发。想了解更多中间件的相关内容,可以阅读本专题下面的文章。

175

2024.05.11

Golang 中间件开发与微服务架构
Golang 中间件开发与微服务架构

本专题系统讲解 Golang 在微服务架构中的中间件开发,包括日志处理、限流与熔断、认证与授权、服务监控、API 网关设计等常见中间件功能的实现。通过实战项目,帮助开发者理解如何使用 Go 编写高效、可扩展的中间件组件,并在微服务环境中进行灵活部署与管理。

212

2025.12.18

chrome什么意思
chrome什么意思

chrome是浏览器的意思,由Google开发的网络浏览器,它在2008年首次发布,并迅速成为全球最受欢迎的浏览器之一。本专题为大家提供chrome相关的文章、下载、课程内容,供大家免费下载体验。

758

2023.08.11

chrome无法加载插件怎么办
chrome无法加载插件怎么办

chrome无法加载插件可以通过检查插件是否已正确安装、禁用和启用插件、清除插件缓存、更新浏览器和插件、检查网络连接和尝试在隐身模式下加载插件方法解决。更多关于chrome相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

721

2023.11.06

windows查看端口占用情况
windows查看端口占用情况

Windows端口可以认为是计算机与外界通讯交流的出入口。逻辑意义上的端口一般是指TCP/IP协议中的端口,端口号的范围从0到65535,比如用于浏览网页服务的80端口,用于FTP服务的21端口等等。怎么查看windows端口占用情况呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

552

2023.07.26

查看端口占用情况windows
查看端口占用情况windows

端口占用是指与端口关联的软件占用端口而使得其他应用程序无法使用这些端口,端口占用问题是计算机系统编程领域的一个常见问题,端口占用的根本原因可能是操作系统的一些错误,服务器也可能会出现端口占用问题。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1078

2023.07.27

windows照片无法显示
windows照片无法显示

当我们尝试打开一张图片时,可能会出现一个错误提示,提示说"Windows照片查看器无法显示此图片,因为计算机上的可用内存不足",本专题为大家提供windows照片无法显示相关的文章,帮助大家解决该问题。

771

2023.08.01

windows查看端口被占用的情况
windows查看端口被占用的情况

windows查看端口被占用的情况的方法:1、使用Windows自带的资源监视器;2、使用命令提示符查看端口信息;3、使用任务管理器查看占用端口的进程。本专题为大家提供windows查看端口被占用的情况的相关的文章、下载、课程内容,供大家免费下载体验。

445

2023.08.02

漫蛙2入口地址合集
漫蛙2入口地址合集

本专题整合了漫蛙2入口汇总,阅读专题下面的文章了解更多详细内容。

13

2026.01.06

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

相关下载

更多

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
进程与SOCKET
进程与SOCKET

共6课时 | 0.3万人学习

Redis+MySQL数据库面试教程
Redis+MySQL数据库面试教程

共72课时 | 6.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号