WebSocketChannel 1.1.0
dotnet add package WebSocketChannel --version 1.1.0
NuGet\Install-Package WebSocketChannel -Version 1.1.0
此命令旨在在 Visual Studio 的包管理器控制台中使用,因为它使用 NuGet 模块的 Install-Package 版本。
<PackageReference Include="WebSocketChannel" Version="1.1.0" />
对于支持 PackageReference 的项目,请将此 XML 节点复制到项目文件中以引用此包。
paket add WebSocketChannel --version 1.1.0
NuGet 团队不提供对此客户端的支持。请联系其 维护者 以获取支持。
#r "nuget: WebSocketChannel, 1.1.0"
#r 指令可用于 F# 交互式和 Polyglot Notebooks。将此内容复制到交互式工具或脚本的源代码中,以引用该包。
// Install WebSocketChannel as a Cake Addin #addin nuget:?package=WebSocketChannel&version=1.1.0 // Install WebSocketChannel as a Cake Tool #tool nuget:?package=WebSocketChannel&version=1.1.0
NuGet 团队不提供对此客户端的支持。请联系其 维护者 以获取支持。
用法
var client = new ClientWebSocket();
await client.ConnectAsync(serverUri, CancellationToken.None);
Channel<ReadOnlyMemory<byte>> channel = client.CreateChannel();
await channel.Writer.WriteAsync(Encoding.UTF8.GetBytes("hello").AsMemory());
// Read single message when it arrives
ReadOnlyMemory<byte> response = await channel.Reader.ReadAsync();
// Read all messages while underlying websocket is open
await foreach (var item in channel.Reader.ReadAllAsync())
{
Console.WriteLine(Encoding.UTF8.GetString(item.Span));
}
// Completing the writer closes the underlying websocket cleanly
channel.Writer.Complete();
// Can also complete reporting an error for the remote party
channel.Writer.Complete(new InvalidOperationException("Bad format"));
The WebSocketChannel
也可用于服务器。以下示例基本上来自 ASP.NET Core 中 WebSockets 的文档,并将其修改为使用 WebSocketChannel
将消息回显到客户端
app.Use(async (context, next) =>
{
if (context.Request.Path == "/ws")
{
if (context.WebSockets.IsWebSocketRequest)
{
using var webSocket = await context.WebSockets.AcceptWebSocketAsync();
var channel = WebSocketChannel.Create(webSocket);
try
{
await foreach (var item in channel.Reader.ReadAllAsync(context.RequestAborted))
{
await channel.Writer.WriteAsync(item, context.RequestAborted);
}
}
catch (OperationCanceledException)
{
try
{
await webSocket.CloseOutputAsync(WebSocketCloseStatus.NormalClosure, null, default);
}
catch { } // Best effort to try closing cleanly. Client may be entirely gone.
}
}
else
{
context.Response.StatusCode = (int) HttpStatusCode.BadRequest;
}
}
else
{
await next();
}
});
赞助商
产品 | 版本 兼容及附加计算的目标框架版本。 |
---|---|
.NET | net5.0 已计算。 net5.0-windows 已计算。 net6.0 已计算。 net6.0-android 已计算。 net6.0-ios 已计算。 net6.0-maccatalyst 已计算。 net6.0-macos 已计算。 net6.0-tvos 已计算。 net6.0-windows 已计算。 net7.0 已计算。 net7.0-android 已计算。 net7.0-ios 已计算。 net7.0-maccatalyst 已计算。 net7.0-macos 已计算。 net7.0-tvos 已计算。 net7.0-windows 已计算。 net8.0 已计算。 net8.0-android 已计算。 net8.0-browser 已计算。 net8.0-ios 已计算。 net8.0-maccatalyst 已计算。 net8.0-macos 已计算。 net8.0-tvos 已计算。 net8.0-windows 已计算。 |
.NET Core | netcoreapp3.0 已计算。 netcoreapp3.1 已计算。 |
.NET Standard | netstandard2.1 兼容。 |
MonoAndroid | monoandroid 已计算。 |
MonoMac | monomac 已计算。 |
MonoTouch | monotouch 已计算。 |
Tizen | tizen60 已计算。 |
Xamarin.iOS | xamarinios 已计算。 |
Xamarin.Mac | xamarinmac 已计算。 |
Xamarin.TVOS | xamarintvos 已计算。 |
Xamarin.WatchOS | xamarinwatchos 已计算。 |
-
.NETStandard 2.1
- System.Threading.Channels (>= 7.0.0)
NuGet 包 (1)
显示依赖于 WebSocketChannel 的顶级 1 个 NuGet 包
包 | 下载 |
---|---|
WebSocketeer
一个轻量级、直观、惯用且高性能的 API,用于 Azure Web PubSub protobuf 子协议。 |
GitHub 仓库
此包未用于任何流行的 GitHub 仓库。