System.Net.WebSockets.WebSocketProtocol 5.1.0

Prefix Reserved
There is a newer prerelease version of this package available.
See the version list below for details.
dotnet add package System.Net.WebSockets.WebSocketProtocol --version 5.1.0                
NuGet\Install-Package System.Net.WebSockets.WebSocketProtocol -Version 5.1.0                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="System.Net.WebSockets.WebSocketProtocol" Version="5.1.0" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add System.Net.WebSockets.WebSocketProtocol --version 5.1.0                
#r "nuget: System.Net.WebSockets.WebSocketProtocol, 5.1.0"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install System.Net.WebSockets.WebSocketProtocol as a Cake Addin
#addin nuget:?package=System.Net.WebSockets.WebSocketProtocol&version=5.1.0

// Install System.Net.WebSockets.WebSocketProtocol as a Cake Tool
#tool nuget:?package=System.Net.WebSockets.WebSocketProtocol&version=5.1.0                

About

Provides the WebSocketProtocol class, which allows creating a WebSocket from a connected stream using WebSocketsProtocol.CreateFromConnectedStream.

NOTE: This package was designed as a temporary solution for internal use (building ASP.NET targeting .NET Standard 2.0), and is now considered obsolete. If targeting .NET Standard 2.1 or .NET 5+, use WebSocket.CreateFromStream instead.

Key Features

  • Creates a new WebSocket instance that operates on the specified transport stream. The WebSocket class allows applications to send and receive data after the WebSocket upgrade has completed.
  • The API can be used to create both client-side and server-side WebSocket instances.

How to Use

To create a WebSocket using WebSocketProtocol, as a prerequisite, you need to prepare the opaque transport stream for the WebSocket, for example, create or accept a TCP socket connection as a Stream and perform a WebSocket opening handshake (upgrade) over it. Then you can use the transport stream and the negotiated subprotocol to call WebSocketProtocol.CreateFromStream.

Stream opaqueTransport = /* ... */; // complete WebSocket opening handshake over the transport connection
WebSocket ws = WebSocketProtocol.CreateFromStream(opaqueTransport, isServer: true, subProtocol, keepAliveInterval);

Remarks

The API is considered obsolete and is not recommented for use.

On .NET Framework or .NET Standard 2.0:

On .NET Core 2.1+, .NET 5+ or .NET Standard 2.1:

Main Types

The main types provided by this library are:

  • System.Net.WebSockets.WebSocketProtocol

Additional Documentation

License

System.Net.WebSockets.WebSocketProtocol is released as open source under the MIT license.

Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  net5.0-windows was computed.  net6.0 is compatible.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed. 
.NET Core netcoreapp2.0 was computed.  netcoreapp2.1 was computed.  netcoreapp2.2 was computed.  netcoreapp3.0 was computed.  netcoreapp3.1 was computed. 
.NET Standard netstandard2.0 is compatible.  netstandard2.1 was computed. 
.NET Framework net461 was computed.  net462 is compatible.  net463 was computed.  net47 was computed.  net471 was computed.  net472 was computed.  net48 was computed.  net481 was computed. 
MonoAndroid monoandroid was computed. 
MonoMac monomac was computed. 
MonoTouch monotouch was computed. 
Tizen tizen40 was computed.  tizen60 was computed. 
Xamarin.iOS xamarinios was computed. 
Xamarin.Mac xamarinmac was computed. 
Xamarin.TVOS xamarintvos was computed. 
Xamarin.WatchOS xamarinwatchos was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (6)

Showing the top 5 NuGet packages that depend on System.Net.WebSockets.WebSocketProtocol:

Package Downloads
Microsoft.AspNetCore.WebSockets

ASP.NET Core web socket middleware for use on top of opaque servers.

Microsoft.AspNetCore.Http.Connections

Components for providing real-time bi-directional communication across the Web.

Microsoft.Azure.SignalR

.NET Standard SDK for Azure SignalR.

Microsoft.Azure.SignalR.Management

Provides communication capabilities with ASP.NET Core SignalR clients through Azure SignalR Service directly. The capabilities include sending messages to all/clients/users/groups and managing group membership. For more information, see https://github.com/Azure/azure-signalr/blob/dev/docs/management-sdk-guide.md

MixinCSharpSdk

Mixin C# SDK is a high performance sdk for mixin. Include Mixin network api, messager api and websocket api.

GitHub repositories (2)

Showing the top 2 popular GitHub repositories that depend on System.Net.WebSockets.WebSocketProtocol:

Repository Stars
Azure/azure-signalr
Azure SignalR Service SDK for .NET
aspnet/WebSockets
[Archived] Implementation of the WebSocket protocol, along with client and server integration components.
Version Downloads Last updated
6.0.0-preview.1.21102.12 16,454 2/12/2021 6.0.0-preview.1.21102.12 is deprecated because it is no longer maintained.
5.1.0 18,283 11/12/2024
5.0.0 1,486,771 11/9/2020
5.0.0-rc.2.20475.5 887 10/13/2020
5.0.0-rc.1.20451.14 894 9/14/2020
5.0.0-preview.8.20407.11 1,350 8/25/2020
5.0.0-preview.7.20364.11 883 7/21/2020
5.0.0-preview.6.20305.6 844 6/25/2020
5.0.0-preview.5.20278.1 821 6/10/2020
5.0.0-preview.4.20251.6 861 5/18/2020
5.0.0-preview.3.20214.6 855 4/23/2020
5.0.0-preview.2.20160.6 876 4/2/2020
5.0.0-preview.1.20120.5 877 3/16/2020
4.7.1 160,334 5/12/2020
4.7.0 91,028 12/3/2019
4.7.0-preview3.19551.4 1,934 11/13/2019
4.7.0-preview2.19523.17 841 11/1/2019
4.7.0-preview1.19504.10 2,429 10/15/2019
4.6.0 991,448 9/23/2019
4.6.0-rc1.19456.4 974 9/16/2019
4.6.0-preview9.19421.4 1,059 9/4/2019
4.6.0-preview9.19416.11 843 9/4/2019
4.6.0-preview8.19405.3 913 8/13/2019
4.6.0-preview7.19362.9 863 7/23/2019
4.6.0-preview6.19303.8 964 6/12/2019
4.6.0-preview6.19264.9 847 9/4/2019
4.6.0-preview5.19224.8 887 5/6/2019
4.6.0-preview4.19212.13 883 4/18/2019
4.6.0-preview3.19128.7 950 3/6/2019
4.6.0-preview.19073.11 3,218 1/29/2019
4.6.0-preview.18571.3 2,056 12/3/2018
4.5.3 40,488,891 1/8/2019 4.5.3 is deprecated because it is no longer maintained.
4.5.2 20,244 10/1/2018 4.5.2 has at least one vulnerability with high severity.
4.5.1 40,084,169 6/18/2018 4.5.1 has at least one vulnerability with high severity.
4.5.0 7,678,952 5/29/2018 4.5.0 has at least one vulnerability with high severity.
4.5.0-rc1 74,367 5/6/2018
4.5.0-preview2-26406-04 71,329 4/10/2018
4.5.0-preview1-26216-02 112,279 2/26/2018